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计算 机 相关 核心 技术 大 部 分 源 于 英语 国家 ,软件 开发 工具 的 主流 及 程序 语言 基本 要 
素 是 英语 。 信 息 技术 日 新 月 异地 发 展 , 如 果 不 擎 握 计 算 机 专业 英语 ,势必 受到 语言 的 制 
约 , 严 重 影响 对 新 技术 的 理解 和 消化 。 所 以 ,从 事 IT 行业 的 人 员 都 需要 擎 握 计算 机 英语 
的 篆 用 术语 和 缩 略 语 .常见 的 语法 和 惯用 法 ,能 借助 字典 熟练 阅读 旭 文 文档 和 技术 资料 。 
“计算 机 专业 瑞 请 ?是 计算 机 及 相关 专业 的 一 门 专业 基础 诛 程 。 

学 习 计 算 机 专业 英语 ,最 好 的 教学 方法 是 对 计算 机 相关 专业 课 采 用 双语 教学 ,但 教学 
研究 型 和 教学 (应 用 ) 型 大 学 的 学 生 , dei BUT .说 、 写 能 力 相 对 偶 弱 ,双语 教学 对 专业 知 
识 的 擎 握 效 果 不 那 么 理想 。 所 以 ,为 了 便于 学 生 擎 握 计算 机 专业 英语 ,只 能 退 而 求 其 次 ， 
通过 选择 有 趣 、 较 易 懂 的 专业 素材 或 软件 工具 相关 实用 内 容 , 让 学 生 重 温 专业 课程 的 知识 
点 ,并 学 会 相关 的 中 英文 专业 词汇 。 专 业 英 语 教 学 课程 成 为 各 门 专 业 诬 程 知识 点 融会 的 
平台 和 载体 ,体现 了 CDIO (构思 (Conceive) 设计 (Design) .实现 (Implement) 和 运作 
( Operate ) ) 的 工程 教学 理念 ,摆脱 了 双语 教学 难以 掌握 专业 知识 的 尴 众 ,也 增 蝇 了 学 习 专 
业 英 语 的 趣味 和 实用 性 ,进一步 增强 了 计算 机 相关 领域 的 应 用 知识 点 和 英汉 专业 术语 的 
对 应 关系 。 

本 书 针对 教学 研究 型 和 教学 (应 用 ) 型 大 学 的 学 生 英 语素 质 特点 ,结合 需要 和 擎 握 的 专 
业 知 识 点 ,从 国内 外 最 近 几 年 计算 机 相关 领域 的 最 新 教材 专著、 论文 和 网 络 信息 中 选取 
了 计算 机 基础 计算 机 网 络 \ 云 计算 ,数据库 程序 设计 语言 MSDN 编译 原理 .离散 数学 、 
软件 工程 .嵌入 式 系统 .数据 结构 与 算法 .操作 系统 等 内 容 素材 。 全 书 共 分 为 11 个 单元 ， 
每 个 单元 的 内 容 相 对 独立 ,包括 课文 A .课文 B .单词 , 难 句 分 析 .语法 .技能 训练 和 阅读 材 
料 ORBIS EE 专业 的 词汇 进行 了 注释 。 修 订 版 增加 了 人 工 智 能 、 科 技 论文 写作 BSF 
文 等 内 容 。 授 课 教师 可 根据 课时 要 求 及 专业 特点 加 以 裁减 。 

印 晓 红 构 想 了 全 书 内 容 和 要 求 ,审查 各 单元 内 容 并 统一 了 全 书 风格 , 吴 沧 海 编写 了 第 
4~10 单元 及 附录 上, 刘 秋明 编写 了 第 1 ~3 单元 .第 11 单元 及 附录 G , 杨 俊 编写 了 附录 相 
关内 容 , 赖 谷 丹 ,杨欣 参与 了 本 书 的 素材 收集 和 整理 工作 。 人 全书 由 印 晓 红 统 稿 并 定稿 。 

本 书 内 容 的 工程 教学 理念 构想 来 日 “基于 布 鲁 姆 教学 理论 的 计算 机 专业 外 语 课程 教 
学 模式 的 研究 和 探讨 “教学 与 科研 有 机 结合 提高 教学 质量 和 学 生 综 合 素质 的 人 研究 
(2008B2ZB04)”"“ 实 施 本 科 生 全 程 导师 制 教育 培养 模式 的 研究 一 一 以 江西 省 高 校 软件 学 
院 为 例 (08YB078) “软件 工程 融合 传统 专业 复合 型 创新 人 才 培 养 模式 研究 (JXJG-12-6- 


15) ”等 教改 课题 的 研究 成 果 , 在 此 特别 感谢 江西 省 教育 厅 江西 理工 大 学 等 有 关 单 位 领 
导 和 教学 管理 部 门 的 文 持 。 在 本 书 的 编写 过 程 中 ,我们 还 参阅 了 大 量 的 专业 英语 书籍 E 
语 网 站 和 有 关 教 学 研究 论文 资料 ,在 此 上 呵 有 关 作者 表示 裹 心 的 感谢 ! 在 本 书 的 使 用 过 程 
中 ,得 到 许多 老师 和 同学 的 指正 ,清华 大 学 出 版 社 对 本 书 的 修订 出 版 工作 给 予 了 大 力 的 文 
持 , 在 此 表示 庄 心 的 感谢 ! 
书 中 难免 有 不 妥 和 错误 之 处 ,恳请 广大 读者 及 同行 专家 批评 指正 ,以 便于 再 版 修订 
完善 。 
编 者 
2018 年 12 月 于 江西 南昌 
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Unit 1 Computer Structure 


Text A The Function of Computer 


1. Central processing unit and microprocessor 


A general purpose computer has four main components. the arithmetic logic unit 
( ALU) , the control unit, the memory, and the input and output devices (collectively termed 
I/O). These parts are interconnected by® buses, often made of® groups of wires. 

Inside each of these parts are trillions of small electrical circuits which can be turned 
off or on by means of an electronic switch. Each circuit represents a bit ( binary digit) of 
information so that when the circuit is on it represents a "1", and when off it represents a 
"0" (in positive logic representation ) . *! The circuits are arranged in logic gates so that one 
or more of the circuits may control the state of one or more of the other circuits. 

The control unit, ALU, registers, and basic L/O ( and often other hardware closely 


linked with these) are collectively known as a central processing unit ( CPU). Early CPUs 


were composed of many separate components but since the mid-1970s CPUs have typically 


been constructed on a single integrated circuit9 called a microprocessor. E 


Since 1985, numerous processors implementing some version of the MIPS architecture 
have been designed and widely used. MIPS ( an acronym for Microprocessor without 
Interlocked Pipeline Stages) is a reduced instruction set computer ( RISC) instruction set 
architecture ( ISA) developed by MIPS Technologies ( formerly MIPS Computer Systems ) . 
The early MIPS architectures were 32-bit called MIPS32, with 64-bit versions added later. 
The MIPS32 instruction set was developed along side the MIPS64 Instruction Set which 
includes 64-bit instructions. The MIP32 standard included coprocessor 0 control instructions 
for the first time. Today, the MIP32 instruction set is the most common MIPS instruction 
set, compatible with most CPUs. Due to its relative simply, the MIP32 instruction set is also 
the most common instruction set thought in computer architecture university courses. MIPS32 
Add Immediate Instruction is shown in Figure 1-1. 


The control unit ( often called a control system or central controller) manages the 


元 件 , 部 件 


oeece 
E 
i 
m 


MIPS32 Add Immediate Instruction 


001000 0000000101011110 


OP Code! Addr 1 | Addr 2 | Immediate Value 


Equivalent mnemonic: addi &rl, &r2, 350 


Figure 1-1 Diagram showing how a particular MIPS architecture 


instruction would be decoded by the control system 


computers various components; it reads and interprets ( decodes )® the program 
instructions, transforming them into® a series of control signals which activate other parts 
of the computer. ® Control systems in advanced computers may change the order of some 
instructions so as to improve performance9. 

A key component common to all CPUs is the program counter; a special memory cell ( a 
register) that keeps track of which location in memory the next instruction is to be read from. 

The control system's function is as follows—note that this is a simplified description, 
and some of these steps may be performed concurrently9 or in a different order depending 
on the type of CPU: 

Read the code for the next instruction from the cell indicated by the program counter. 

Decode the numerical code for the instruction into a set of commands or signals for each 
of the other systems. 

Increment® the program counter so it points to the next instruction. 

Read whatever data the instruction requires from cells in memory ( or perhaps from an 
input device). The location of this required data is typically stored within the instruction 
code. 

Provide the necessary data to an ALU or register. 

If the instruction requires an ALU or specialized hardware to complete, instruct the 
hardware to perform the requested operation. 

Write the result from the ALU back to® a memory location or to a register or perhaps 
an output device. 

Since the program counter is ( conceptually ) just another set of memory cells, it can be 


changed by calculations done in the ALU. Adding 100 to the program counter would cause 
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the next instruction to be read from a place 100 locations further down the program. 
Instructions that modify the program counter are often known as "jumps" and allow for loops 
( instructions that are repeated by the computer) and often conditional instruction execution 
( both examples of control flow). 

It is noticeable that the sequence® of operations that the control unit goes through to 
process an instruction is in itself like a short computer program—and indeed, in some more 
complex CPU designs, there is another yet smaller computer called a microsequencer that 


runs a microcode program that causes all of these events to happen. 
2. Arithmetic/Logic Unit( ALU) 


The ALU is capable of® performing two classes of operations; arithmetic and 
logic. 

The set of arithmetic operations that a particular ALU supports may be limited to adding 
and subtracting or might include multiplying or dividing or trigonometry functions 
(sine, cosine, etc. ) and square roots. $ Some can only operate on whole numbers 
(integers) whilst others use floating point to represent real numbers—albeit with® limited 
precision. However, any computer that is capable of performing just the simplest operations 
can be programmed to break down the more complex operations into simple steps that it 
can perform. 755 Therefore, any computer can be programmed to perform any arithmetic 
operation—although it will take more time to do so if its ALU does not directly support the 
operation. An ALU may also compare numbers and return boolean® truth values (true or 
false) depending on whether one is equal to®, greater than® or less than® the other 
(“is 64 greater than 65?" ). 

Logic operations involve Boolean logic: AND, OR, XOR and NOT. These can be 
useful both for creating complicated conditional statements and processing Boolean logic. 

Superscalar® computers may contain multiple® ALUs so that they can process 


several instructions at the same time. Graphics processors and computers with SIMD and 
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MIMD features often provide ALUs that can perform arithmetic on vectors9 and 


matrices9. 
3. Memory 


Computer data storage9 , often called storage or memory, is a technology consisting of 
computer components and recording media that are used to retain digital data. Magnetic-core 
memory shown as Figure 1-2 was the predominant form of random-access computer memory 
for 20 years between about 1955 and 1975. 


Figure 1-2 | Magnetic core memory was the computer memory of choice 


Magnetic core memory was popular main memory for computers through the 1960s, 
until it was replaced by semiconductor memory. 

A computer's memory can be viewed as a list of cells into which numbers can be placed 
or read. Each cell has a numbered "address" and can store a single number. The computer 
can be instructed to “put the number 123 into® the cell numbered 1357” or to “add the 
number that is in cell 1357 to the number that is in cell 2468 and put the answer into cell 
1595". * The information stored in memory may represent practically anything. Letters, 
numbers, even computer instructions can be placed into memory with equal ease. Since the 
CPU does not differentiate between different types of information, it is the software's 
responsibility to give significance to what the memory sees as nothing but a series of 
numbers. 

In almost all modern computers, each memory cell is set up to store binary numbers in 
groups of eight bits ( called a byte). Each byte is able to represent 256 different numbers 
(2° 2256); either from 0 to 255 or — 128 to +127. To store larger numbers, several 
consecutive bytes may be used (typically, two, four or eight). When negative numbers 
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are required, they are usually stored in two's complement notation. Other arrangements are 
possible, but are usually not seen outside of specialized applications or historical contexts. 
A computer can store any kind of information in memory if it can be represented numerically. 
Modern computers have billions or even trillions of bytes of memory. 

The CPU contains a special set of memory cells called registers that can be read and 
written too much more rapidly than the main memory area. There are typically between 
two and one hundred registers depending on the type of CPU. Registers are used for the most 
frequently needed data items to avoid having to access main memory every time data is 
needed. *’ As data is constantly being worked on, reducing the need to access main memory 
(which is often slow compared to the ALU and control units) greatly increases the 
computer's speed. 

Computer main memory comes in two principal varieties; random-access memory or 
RAM and read-only memory or ROM. RAM can be read and written to anytime the CPU 
commands it, but ROM is pre-loaded with data and software that never changes, so the CPU 
can only read from it. %8 ROM is typically used to store the computer's initial start-up 
instructions. In general, the contents of RAM are erased when the power to the computer is 
turned off, but ROM retains its data indefinitely. In a PC, the ROM contains a specialized 
program called the BIOS that orchestrates loading the computer's operating system from the 
hard disk drive into RAM whenever the computer is turned on or reset. In embedded9 
computers, which frequently do not have disk drives, all of the required software may be 
stored in ROM. Software stored in ROM is often called firmware®, because it is notionally 
more like hardware than software. Flash memory blurs the distinction between ROM and 
RAM, as it retains its data when turned off but is also rewritable. It is typically much slower 
than conventional ROM and RAM however, so its use is restricted to applications 
where high speed is unnecessary. 

In more sophisticated computers there may be one or more RAM cache memories which 
are slower than registers but faster than main memory. e Generally computers with this sort 
of cache are designed to move frequently needed data into the cache automatically, often 


without the need for any intervention on the programmer's part. 
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4. Input/Output (L/0) 


L/O is the means by which a computer exchanges information with the outside world. 
Devices that provide input or output to the computer are called peripherals. 9 On a typical 


rsonal computer, peripherals include input devices like the keyboard and mouse, and 


output devices such as the display and printer. *" Hard disk drives shown as Figure 1-3, 
floppy disk drives? and optical disc® drives serve as both input and output devices. 


Computer networking is another form of I/O. 


Figure 1-3 Hard disk drives are common storage devices used with computers 


Often, L/O devices are complex computers in their own right with their own CPU and 
memory. A graphics processing unit might contain fifty or more tiny computers that perform 
the calculations necessary to display 3D graphics. Modern desktop computers contain many 
smaller computers that assist the main CPU in performing I/O. 


5. Multitasking 


While a computer may be viewed as running one gigantic program stored in its main 
memory, in some systems it is necessary to give the appearance of running several programs 
simultaneously. This is achieved by multitasking, i. e. having the computer switch 
rapidly between running each program in turn. 

One means by which this is done is with a special signal called an interrupt which 
can periodically cause the computer to stop executing instructions where it was and do 
something else instead. EM By remembering where it was executing prior to the interrupt, the 


computer can return to that task later. The interrupt generator might be causing several 
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hundred interrupts per second, causing a program switch each time, if several programs are 
running "at the same time". Since modern computers typically execute instructions several 
orders of9 magnitude faster than® human perception, it may appear that many programs 
are running at the same time even though only one is ever executing in any given instant. 
This method of multitasking is sometimes termed "time-sharing" since each program is 
allocated a “slice” 9 of time in turn. 

Before the era of cheap computers, the principle use for multitasking was to allow many 
people to share the same computer. 

Seemingly, multitasking would cause a computer that is switching between several 
programs to run more slowly—in direct proportion to the number of programs it is 
running. However, most programs spend much of their time waiting for slow input/output 
devices to complete their tasks. If a program is waiting for the user to click on the mouse or 
press a key on the keyboard, then it will not take a "time slice" until the event it is waiting 
for has occurred. This frees up time for other programs to execute so that many programs 


may be run at the same time without unacceptable speed loss9. 
6. Multiprocessing 


Some computers are designed to distribute® their work across several CPUs in a 
multiprocessing configuration, a technique once employed only in large and powerful 
machines such as supercomputers, mainframe® computers and servers. *" Multiprocessor 
and multi-core ( multiple CPUs on a single integrated circuit) personal and laptop computers 
are now widely available, and are being increasingly used in lower-end markets as a result 
shown as Figure 1-4. 

Supercomputers in particular often have highly unique architectures that differ 
significantly from the basic stored-program architecture and from general purpose computers. 


They often feature thousands of CPUs, customized high-speed interconnects, and specialized 


computing hardware. i5 Such designs tend to be useful only for specialized tasks due to the 


large scale of program organization required to successfully utilize most of the available 
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resources at once. Supercomputers usually see usage in large-scale simulation®, graphics 


rendering , 


“embarrassingly® parallel" tasks. *™ 


7. Networking and the Internet 
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Figure 1-4 Cray designed many supercomputers that used multiprocessing heavily 


Computers have been used to coordinate information between multiple locations since 


the 1950s. The U.S. military's SAGE system was the first large-scale example of such a 


system, which led to a number of® special-purpose commercial systems like Sabre. 


In the 1970s, computer engineers at research institutions throughout the United States 


began to link their computers together using telecommunications technology. =15 This effort 


was funded by ARPA (now DARPA) , and the computer network that it produced was called 
the ARPANET. The technologies that made the ARPAnet® possible spread and evolved. 


In time®, the network spread beyond academic and military institutions and became 


known as the Internet shown as Figure 1-5. The emergence of networking involved a 


redefinition® of the nature and boundaries of the computer. Computer operating systems 


and applications were modified to include the ability to define and access the resources of 


other computers on the network, such as peripheral devices, stored information, and the like, 
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as extensions of the resources of an individual computer. *'^ Initially these facilities were 
available primarily to people working in high-tech environments, but in the 1990s the spread 
of applications like E-mail and the World Wide Web, combined with the development of 
cheap, fast networking technologies like Ethernet and ADSL saw computer networking 
become almost ubiquitous. In fact, the number of computers that are networked is growing 
phenomenally. A very large proportion of personal computers regularly connect to the 


Internet to communicate and receive information. “ Wireless "9 networking, often 


utilizing® mobile phone networks, has meant networking is becoming increasingly 


ubiquitous even in mobile computing environments. 一 “ 


Figure 1-5 Visualization of a portion of the routes on the Internet 
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Exercises 


[Ex1] Answer the questions according to the text: 


(1) How many components does a general purpose computer have? And what are they? 
(2) What is a central processing unit? 

(3) What is the control unit's main task? 

(4) What are the ALU operations? 

(5) What is L/O? Can you list some input devices? 


[Ex2] Translate into Chinese: 


(1) Inside each of these parts are trillions of small electrical circuits which can be turned 
off or on by means of an electronic switch. Each circuit represents a bit ( binary digit) of 
information so that when the circuit is on it represents a "1", and when off it represents a 
"0" (in positive logic representation ) . 

(2) Adding 100 to the program counter would cause the next instruction to be read from 
a place 100 locations further down the program. Instructions that modify the program counter 
are often known as "jumps" and allow for loops (instructions that are repeated by the 
computer) and often conditional instruction execution (both examples of control flow). 

(3) The set of arithmetic operations that a particular ALU supports may be limited to 
adding and subtracting or might include multiplying or dividing or trigonometry functions 
(sine, cosine, etc. ) and square roots. Some can only operate on whole numbers ( integers ) 
whilst others use floating point to represent real numbers—albeit with limited precision. 

(4) Computer main memory comes in two principal varieties; random-access memory 
or RAM and read-only memory or ROM. 

(5) While a computer may be viewed as running one gigantic program stored in its main 
memory, in some systems it is necessary to give the appearance of running several programs 


simultaneously. 
[Ex3] Choose the best answer: 


(1) Some computers are designed to their work across several CPUs in a 


multiprocessing configuration. 


A. distribute B. distributed 
C. distributing D. distributes 
(2) One means by which this is done is with a special signal called an which 


can periodically cause the computer to stop executing instructions where it was and do 
something else instead. 
. 12 . 


A. pause B. stop C. interrupt D. exit 


(3) Hard disk drives, floppy disk drives and drives serve as both input and 
output devices. 
A. Optical magnetic B. keyboard 
C. mouse D. optical disc 


(4) In almost all modern computers, each memory cell is set up to store binary numbers 
in groups of (called a byte). Each byte is able to represent 256 different numbers 
(2° 2256) ; either from 0 to 255 or —128 to +127. 

A. One bit B. two bits. C. eight bits D. eight bit 

(5) A general purpose computer has four main components; the arithmetic logic unit 
(ALU), , the memory, and the input and output devices ( collectively termed 
YO). 

A. the control unit B. mouse 
C. display D. disc 


批 注 

注 1 主语 : Each circuit; 谓语 : represents ;so that 引导 了 一 个 目的 状语 从 揣 ;when the circuit is on 是 
目的 状语 从 名 的 主语 ;it 为 代词 ;and when off 与 when the circuit is on 是 并 列 的 从 语 主 语 。 

ik2 主语 : Early CPUs; 谓 语 : were composed of, have typically been constructed 为 谓语 ,通过 but 
把 两 句 话 并 列 ;called a microprocessor 后 置 定语 修饰 integrated circuit, 

注 3 主语: The control unit; 谓 语 : manages, it 是 代词 , 指 control unit; transforming 分 词 引 导 独 立 
结构 ; which activate other parts of the computer 的 先行 词 为 control signals, 

注 4 主语 : arithmetic operations, that 引导 一 个 同位 语 从 名 ;particular ALU 72 “J + i8 ; supports 
是 从 名 谓语 ;may be limited to 与 might 为 并 列 结 构 。 

注 5 主语 : any computer; 谓 语 : can be programmed, 主语 从 人 名: that is capable of performing just 
the simplest operations ; programmed... into; 将 …… 编程 转换 为 。 

注 6 主语 : computer; ii: can be instructed to, put the number 123 into the cell numbered 1357 与 
add the number that is in cell 1357 to the number 为 并 列 结构 ; that is in cell 2468 ,先行 词 为 number。 

ik 7 depending on the type of CPU 分 词 短 语 作 定语 ,修饰 registers ; Registers 为 主语 ;are used Ain 
语 ;data is needed 前 面 省 略 了 了 when ,为 时 间 定 语 从 句 。 

注 8  random-access memory and read-only memory or ROM 是 two principal varieties 的 同位 语 ; 句 子 
主语 : computer main memory ;so the CPU can only read from it 为 结果 状语 从 人 铝 。 

注 9 In more sophisticated computers 为 状语 ;which are slower than registers 的 先行 词 为 RAM cache 
memories; but faster than main memory 省 略 y which are, 

ik 10 that provide input or output to the computer AY 7E 1T in] 7j Devices; ©) F 3: Wi iG; devices are 
called. ix “Jif input device like the keyboard and mouse, and output devices such as the display and printer 
为 并 列 的 关系 ,都 属于 peripherals, 

注 11 by which this is done 引导 一 个 定语 从 句 , 它 的 先行 词 是 one means; which can periodically 
cause the computer to stop executing instruction 的 先行 词 是 interrupt ,引导 一 个 定语 从 句 。 


注 12 主语 : Some compnuters; 谓 霹 : are designed to, a technique once employed only in large and 
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powerful machines such as supercomputers, mainframe computers and servers 这 人 句 省 略 y which ,为 非 限制 
性 定语 从 句 。 

注 13 customized high-speed interconnects 前 面 省 略 了 They often; and specialized computing 
hardware 前 面 省 略 了 They often, 

注 14 graphics rendering 前 面 省 略 了 supercomputers usually see usage in; cryptography ( 密码 学 ) 
applications 前 面 省 略 了 supercomputers usually see usage in, 

注 15 In the 1970s 为 时 间 短 语 ; computer engineers 为 句子 主语 ; began to 为 谓语 ; at research 
institutions 是 状语 ; throughout the United States 是 定语 ;link ... together 意 为 : 把 ……- 相连 接 ; using 
telecommunications technology 为 方式 状语 ,意思 是 : 通过 使 用 .…… 

注 16 Computer operating systems and applications 为 主语 ; were modified to; 被 动 语 态 , 被 适应 
Ae ;include... and: 包含 ;and the like: 等 等 ;as extensions of: EJ 的 扩展 。 

注 17 “Wireless” networking 为 句子 的 主 霹 ;often utilizing mobile phone networks 对 前 面 wireless 
networking 补充 说 明 ; 谓 霹 : has meant;networking is becoming... 这 人 句 前 面 省 略 y that, 


Text B The Future of Computer Technology 


Over time, people have always wanted the fastest computer they could get, right? 


When the 386 came out, everyone thought it was TO 


HUNT.. PECK. 


blazing® fast, and needed one. 
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the 386 became slow, and the 486 came out, and everyone Pea COMPUTER THEY 


MAKE, 

needed one. 
The trend is that we use hardware performance as it 
becomes available, and then want more. Kind of like the 


“never enough money” argument. 


But the assumption® that this trend will continue is 
flawed9. 

The fact is your average Joe only needs a computer to do so much. Basically, the 
computer as an * appliance "9 is able to fully interact with our senses, which are 
limited. This means, until we see the smell-o-mouse®, we essentially need: 

Full speed video output: 


Movie decoding/ presentation/ generation, gaming; 
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Full speed video input: 

Vision recognition, movie saving/encoding/compressing ; 

Full speed audio output: 

Sound decoding/mixing, voice synthesis ; 
Full speed audio input: 
Voice recognition, recording/compressing ; 

Realize this argument applies to the “ Average Joe" -not computer geeks® like you and I 
who will want to run huge simulations and do software development or CAD, and will still 
need to have a full-powered workstation at home. =I We are the minority9. 

Most of these requirements are currently available with today's computers. Many of 
them are also available, just not at full speed yet (such as full video generation, ‘flawless’ 
voice recognition ) and will be available with off-the-shelf® computing equipment in a 
matter of years. 

Have you noticed that people don't talk as much about processor speed? If you go into 
your local computer store, they talk these days just as much about RAM, disk, screen size, 
battery and other features. It was only a few years ago where processor speed was king, and 
now it's becoming less vital, and soon it will only be a footnote® to the specs that a 
computer will advertise9. 

So then what happens? 

Things are going to get much smaller, and fast. 

It used to be that a laptop was a bulky and slow and weak machine. ® It couldn't do all 
the tasks of a home computer. This isn't true anymore, my 2 pound ultra-slim laptop ( which 
I paid $150 for; incidentally), can basically keep up with my state-of-the-art home 
workstation. ^? You can already see the emergence of more and more powerful small 
computers. Things like Palm are only the temporary 9 off shoots of a new direction in 
business. Palm is a subset of a real OS, and a subset € of a real computer. Pretty soon 
you'll be able to get a full computer in the same size as a Palm, and it will cost about the 


same. Which would you rather have, the personal organizer that has a built-in micro 
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browser, or the personal organizer that you just downloaded the latest Netscape®/ 
Mozilla9/ Opera9 into with the newest version9 of flash/ java/ shockwave?** The 
personal organizer9 that has a provided address list app. or one that can run any address 
list app you want, and play Doom®? 

This whole argument applies to data storage as well. 

Everyone wants the biggest hard drive/RAM they can get. We keep coming up with 
more ways to fill them up ( mp3s, video...) , and we need to keep upgrading. Although 
these days, running out of space on your hard drive is a much rarer occurrence. I used to 
have to juggle® things between compressing files and moving them to floppy disk storage. 

These days I don’t even own any disks. And I only write CDs generally as a backup 
method for information that is also on my computer. 

In less than 10 years you will be able to store full videos on your hard drive just like you 
can store audio on there today. You’ll have a movie playlist with 1000’s of movies, just like 
your mp3 player today. 

And a few years later you’ll be able to put this on the end of your keychain®. Are you 
really going to need to get a bigger hard drive after that? At some point you’ll be able to store 
more video and audio than you'll ever be able to experience in® your continuous 
lifetime®. At that point, you won't need the next drive size, now will you? 

I admit there's one big difference between my laptop and my home computer. And that's 
the keyboard, the 21" monitor and the CD-RW. ( Though most laptops9 have DVD/CD- 
RW these days...) 

Now let's look at the future. 

But before doing that, consider the past, consider what has happened with the computer 
industry. 

Initially the money was in mainframes. Personal computers existed as a sort of clunky 
hobby®, but the bucks were flowing in the mainframe industry9. And that has 
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everything to do with how useful a PC could be compared to a mainframe. As performance 
increased, servers started to do lots of things that mainframes could do, and the $ $ was in 
the mainframes® market. The real issue is that there is a certain amount of computing 
power (per dollar) that actually is critically useful. Anything less than that and it'll be too 
slow, and you'll want more speed. Anything more powerful than that and it'll only be useful 
on the fringe, in the technical and development markets. Then it was workstations, and 
they started to reach this quantum of computing and started replacing servers. Then it was 
PCs. The PC market took off and PCs started to replace workstations. This watermark 


was best publicized in the movie industry when movies like Titanic were advertised to have 


been created for less money by using huge PC farms instead of workstation farms. H5 Now 
we're moving towards laptops, and then subnotebooks will be next, then handhelds. Finish 


the progression yourself. 

So here's my forecast? for the future. 

You'll have a computing unit. It will be a processor that is xxx MHz, where ‘xxx?’ is 
" fast enough. " It will also have solid state storage that is xxx GB, where ' xxx' is "big 
enough. " And this little guy will be the size of a cell phone or smaller, and cost about the 
same. 

And you'll go home and drop it into a port that hooks it up to a monitor and 
keyboard. And on the road you'll put it in a shell with a Palm sized touch display that lets 
you access all of your info, and even listen to music or watch a video besides. And then you 
might pop it into® your camera shell (or your organizer shell might have a lens on it.. ) , 
and you can take as many pictures as you want, because your storage space can hold 1000's 
of movies, so you'll never fill it up with stills/home video, and you'll never have to sync 
with your home machine. ^ You may even have full wireless, and your photos can 
automatically go online to your web photo album. When you get home from your trip, 
you can drop the unit into your theater system and you can watch movies or see footage 
from your trip. You could put some form of net-currency encrypted on? your unit, so 
you can use it to purchase things as well. You could put it in your car when you are driving 


and listen to every song you own. You could have a GPS in your car and it could use a 
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service like Map Quest® to give you directions. And your sweetie will send you email and 
you'll use a headset peripheral and telephony software to call her back™’. 

But the important point is that you won't need to get multiple computing units, and you 
won't need to have a home computer anymore. You'll have one computing unit, and it will 
go with you like a wallet, because it will replace your credit cards, your cell phone, your fax 
machine, your DVD player, your stereo, your browser, your organizer9, your 
email, etc. . ?? 

And then there will be some museum where all these towers and cases sit, and people 


can go look at them and chuckle just like we laugh at ENIAC and the vacuum tube? today. 


Words 
advertise vt. & vi. (动词 ) 公布 ,宣传 
album n. (474) 粘贴 短 ,集邮 短 ,相册 
appliance n. (名 词 ) [P BR, RE 
apps n. (474) applications 的 缩写 
blazing adj. (形容 词 ) 酷热 的 ;炽热 的 
doom n. (名 词 ) 厄运 ;死亡 ;判决 ;世界 末日 
flawed adj. (形容 词 ) A RH , 7A BH N ; A HK IG BY 
footnote n. (474) 脚注 
forecast v. (动词 ) 预见 
geek n. (名 词 ) 怪 杰 
hook vt. &vi. (动词 ) PTE, m EE dE (E 
juggle n. (名 词 ) E da , wi Bl 
keychain n. (474) 钥匙 链 
laptop n. (名 词 ) 掌上 计算 机 
mainframe n. (名 词 ) 主机 
mapquest vt. &vi. (动词 ) 地 图 定位 
minority adj. (形容 词 ) 少数 ,小 部 分 
Mozilla n. (名 词 ) Mozilla 公司 开发 的 一 款 浏览 器 
Netscape n. (474) 美国 Netscape 公司 开发 的 浏览 器 
Opera n. (名 词 ) Opera 软件 公司 制造 的 一 款 浏 览 器 
organizer n. (名 词 ) CES NP EST: 
subset n. (名词 ) TE 
© 地 图 定位 
NECS CONGUE T. 


@ 真空 管 ,电子 管 
Ties 


temporary adj. (形容 词 ) 临时 的 ,暂时 的 


version n. (名 词 ) 版 本 ,形式 

vital adj. (形容 词 ) 极 重要 的 , 必 不 可 少 的 

watermark n. (名词) 水 印 
Phrases 

be able to 能 够 

clunky hobby 嗜好 ;业余 爱好 

continuous lifetime 持续 一 生 

encrypted on 加 密 

experience in 有 经 验 ; 有 ……: 的 经 验 

footage from your trip 从 你 的 旅行 镜头 开始 

from your trip 从 你 的 旅行 开始 

in the mainframe industry 在 大 型 机 主导 时 期 

interact with Eee 相互 作用 

off-the-shelf 现成 的 ;第 备 的 ;成 品 的 

on the fringe 边缘 

personal organizer 个 人 信息 管理 器 

pop---into 匆匆 地 走 进 …… 

smell-o-mouse Bie "nt FAL AS 

state-of-the-art 最 先进 的 

vacuum tube 真空 管 ,电子 管 


批 注 

注 1 Average Joe 与 geeks 对 应 , 意 为 平常 人 与 怪 杰 ;not computer geeks 这 里 作为 插入 语 ;who 引导 
一 个 主语 从 句 ,先行 词 为 you and I;run 5 do need 并 列 。do software development; 从 事 软 件 开 发 工作 。 

注 2 used to be; WAH ; that 引导 一 个 宾语 从 名 ;a laptop 是 从 句 主语 ;a bulky, slow and weak 
machine 为 表 语 。 

注 3 laptop 为 主语 ;can keep up with 为 谓 场 ;my 2 pound ultra-slim {EE IH- 

注 4 the personal organizer that has a built-in micro browser 与 the personal organizer that you just 
downloaded 为 并 列 结构 ,各 有 that 5| &&— 1 4E i MJ, downloaded into; 将 最 新 的 flash/java/shockwave 
装载 到 Netscape/ Mozilla /Opera. 

iE5 when 引导 一 个 时 间 状 语 从 名 ;instead of workstation farms 省 略 f using. 

注 6 you can take as many pictures as you want 这 是 一 个 比较 句 , 与 …… 一 样 多 ;sync with; 与 …… 
同步 。 

注 7 由 三 个 简单 并 列 句 组 成 ;sweetie 表示 甜心 ;headset peripheral; 戴 在 头 上 的 耳机 或 听 简 。 

注 8 because 引导 一 个 原因 状语 从 名 ;your credit cards, your cell phone, your fax machine, your 
DVD player, your stereo, your browser, your organizer, your email 为 并 列 结构 ,省略 了 replace。 
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Associated Reading 


Brief Introduction of Motherboard 


Motherboard is one of the main components of a computer and made of the printed 
circuit board (PCB). The motherboard is also known as mainboard, system board, logic 
board or sometimes, shortened as “mobo”. It serves as the backbone of a system because it 
provides all the electrical connections by which other components of the system 
communicate. Aside from that, it hosts the central processing unit (CPU), and other 


devices. This is illustrated in Figure 1-6. 
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Figure 1-6 The picture of motherboard 


He 注 
(1) memory; 内 存 
(2) memory slot: VJTfdfité 
(3) CPU slot. CPU jfi fé 
(4) CPU; 中 央 处 理 器 
(5) floppy drive: 软盘 驱动 大 
(6) floppy port; 软驱 接口 
(7) CD-ROM drive; 光盘 驱动 器 
(8) IDE port: IDE 接口 
(9) network interface card. 网 卡 
(10) sound card. 声卡 


s Oy s 


(11) video display card; 显示 卡 
(12) ISA slot; ISA ffi f 

(13) PCI slot: PCI fit 

(14) AGP slot: AGP jfifé 

(15) power socket. 电源 插座 
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Unit2 Programming Language 


Text A Functions in C 


Almost all programming languages have some equivalent of the function. You may 
have met them under the alternative names subroutine® or procedure. 局 

Some languages distinguish between functions which return variables and those 
which don't. '? C assumes that every function will return a value. If the programmer wants a 
return value, this is achieved using the return statement. If no return value is required, none 
should be used when calling the function. 

Here is a function which raises a double to the power of an unsigned, and returns the 


result. 


double power (double val, unsigned pow) 
{ double ret val=1.0; 
unsigned i; 


for (i=0; i< pow; i+ +) 
ret val * — val; 


retum(ret val); 
} 


The function follows a simple algorithm@ multiplying the value by itself pow9 times. 
A for loop is used to control the number of multiplications, and variable ret val stores the 
value to be returned. “* Careful programming has ensured that the boundary condition? is 
correct too. 


Let us examine the details of this function: 


double power (double val, unsigned pow) 
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This line begins the function definition. It tells us the type of the return value, the name 
of the function, and a list of arguments used by the function. The arguments and their types 
are enclosed in brackets, each pair separated by commas. 

The body of the function is bounded by a set of curly brackets. Any variables 


declared here will be treated as local unless specifically declared as@ static or extern types. 
retum(ret val); 


On reaching a return statement, control of the program returns to the calling function. 


The bracketed value is the value which is returned from the function. If the final closing curly 


bracket is reached before any return value, then the function will return automatically, any 


return value will then be meaningless. ** 


The example function can be called by a line in another function which looks like this: 


result — power (val, pow) ; 


This calls the function power assigning the return value to variable result. 
Here is an example of a function which does not return a value. 

void error line (int line) 

{ fprintf (stderr, "Error in input data: line $ d\n", line); 

} 


The definition uses type void which is optional. ? It shows that no return value is used. 
Otherwise the function is much the same as® the previous example, except that there is no 
return statement. ** Some void type functions might use return, but only to force an early exit 
from the function, and not to return any value. This is rather like® using break to jump out 
of a loop. *¥ 


This function also demonstrates a new feature. 
fprintf (stderr, "Error in input data: line $ d\n", line); 
This is a variant on the printf statement; fprintf sends its output into a file. In this case, 


the file is stderr. stderr is a special UNIX file which serves as the channel for error messages. 


It is usually connected to the console of the computer system, so this is a good way to display 


8 " ‘ 
error messages from your programs. "5 Messages sent to stderr will appear on screen even if 
ito 


the normal output of the program has been redirected to a file or a printer. 


The function would be called as follows: 


括号 内 
大 括号 
声明 
相同 
DES 


x 


error line(line number); 


Words 
algorithm n. (名 词 ) [ 计 ][ 数 ] 算法 ,运算 法 则 
alternative adj. (形容 词 ) 供 选 择 的 ;选择 性 的 ;交替 的 
equivalent adj. (形容 词 ) 等 价 的 ,相等 的 ;同意 义 的 
pow n. (名 词 ) X m 
subroutine n. (名 词 ) 子 程序 
variable n. (名 词 ) 变量 ;可 变 物 ,可 变 因 素 
Phrases 
a set of curly brackets 大 括号 
boundary condition [ 数 ] 边界 条 件 ,界面 条 件 
declared as 声明 
distinguish between 区 别 ;分 辩 
in brackets 括号 内 
rather like 而 不 像 
the same as 相同 
Exercises 


[Ex1] Answer the questions according to the text: 


(1) What is C? What does that mean? 

(2) What is the file stderr for? 

(3) What is the boundary of a function body? 

(4) What are the standard types for variables in C? 


(5) How does the way your program remember things? 
[Ex2] Translate into Chinese: 


(1) Careful programming has ensured that the boundary condition is correct too. 
(2) The arguments and their types are enclosed in brackets, each pair separated by 
commas. 
(3) The example function can be called by a line in another function which looks like 
this. 
(4) The body of the function is bounded by a set of curly brackets. 
E d 


(5) This is a variant on the printf statement, fprintf sends its output into a file. 

(6) Stderr is a special UNIX file which serves as the channel for error messages. 

(7) Messages sent to stderr will appear on screen even if the normal output of the 
program has been redirected to a file or a printer. 


(8) This calls the function power assigning the return value to variable result. 


[Ex3] Choose the best answer: 


(1) In C Language,a is a series of characters enclosed in double quotes. 
A. matrix B. string C. program D. stream 
(2) In C Language, are used to create variables and are grouped at the top of 


a program block. 
A. declarations B. dimensions C. comments D. descriptions 
(3) A consists of the symbols, characters, and usage rules that permit people 


to communicate with computer. 


A. programming language B. network 
C. storage D. function 
(4) A (An) software, also called end-user program, includes database 


programs , word processors, spreadsheets etc. 


A. application B. system C. compiler D. utility 
(5) If no return value is required, should be used when calling the function. 
A. a value B. some value C. none D. no Frequency 


批 注 

注 1 under the alternative names; 称呼 为 ;主语 : you; 谓 语 : have met, or procedure 前 省 略 y under 
the name ,此 句 的 含义 : 你 可 能 遇 到 过 称 为 子 程序 或 进程 的 图 数 。 

注 2 which 引导 一 个 定语 从 句 ;those 是 指 functions; which don't 省 略 了 return variables, 

注 3 主语 : for loop, 其 含义 是 指 一 个 for 循环 ;multiplications 这 个 单词 为 复合 词 ,其 含义 是 指 多 
个 应 用 程序 。 此 句 的 含义 是 : 一 个 for 语句 用 来 控制 一 些 复合 应 用 程序 ,而 变量 ret. val 用 来 存储 返回 
WA. 

TE4 if SIS — TAPER), WR AK HAA TAR LB ZA AA PR CHF A z [n] 
一 个 值 ,后 面 写 的 任何 返回 值 都 无 意义 。 

TES 此 句 话 的 含义 是 指 这 个 定义 使 用 的 是 void 类 型 ,这 个 属性 是 可 选 的 。 

注 6 API PHC AS A — HE, ,除了 含有 一 个 返回 语句 不 同 之 外 。 

注 7 这 有 点 类 似 于 使 用 break 语句 跳出 loop 循环 。 

注 8 它 通 稼 与 控制 台 连 接 ,这 样 可 以 更 好 地 把 程序 中 的 错误 显示 出 来 。 

注 9 主语 : Messages sent to stderr; 谓 语 : will appear;even if 引导 一 个 条 件 状语 从 句 ;redirected 是 
TH 3 XE [8] ,这 人 句 话 的 含义 是 把 消息 传送 给 stderr ,通过 stderr 把 消息 显示 在 屏幕 上 , 即 笛 见 的 程序 输出 是 
把 程序 重 定 向 至 一 个 文件 或 打印 机 。 
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Text B J2ME Related 


1. How J2ME is organized 


Traditional computing devices use fairly standard hardware configurations such as a 
display, keyboard, mouse, and large amounts of memory and permanent storage. 

However, the new breed of computing devices lacks hardware configuration 
continuity9 among devices. Some devices don't have a display, permanent storage, 
keyboard, or mouse. And memory availability is inconsistent among small computing 
devices. 

The lack of uniform hardware configuration among the small computing devices poses a 
formidable challenge for the Java Community Process Program, which is charged with 
developing standards for the JVM and the J2ME for small computing devices. 

J2ME must service many different kinds of small computing devices, including screen 
phones, digital set-top boxes O used for cable television, cell phones, and personal digital 
assistants. *' The challenge for the Java Community Process Program is to develop a 
Java standard that can be implemented on small computing devices that have nonstandard 
hardware configurations. 

The Java Community Process Program has used a twofold approach to addressing. 

The needs of small computing devices. First, they defined the Java run-time 
environment and core classes that operate on each device. This is referred to as the 
configuration. A configuration defines the Java Virtual Machine for a particular small 
computing device. There are two configurations, one for handheld devices and the other 
for plug-in devices. Next, the Java Community Process Program defined a profile for 
categories of small computing devices. "A profile consists of classes that enable developers 


to implement features found on a related group of small computing devices. 
2. J2ME configurations 


There are two configurations for J2ME as of this writing. These are Connected Limited 
Device Configuration (CLDC) and the Connected Device Configuration (CDC). The CLDC 


品种 ,类 型 
延续 性 ,一 系列 

内 存 容量 

难以 克服 的 ,巨大 的 
承担 ,负责 

机 顶 盒 

Java 社团 处 理 程序 
手持 式 


N 
ON 


is designed for 16-bit or 32-bit small computing devices with limited amounts of memory. 
CLDC devices usually have between 160KB and 512KB of available memory and are 
battery powered. They also use an inconsistent, small-bandwidth network wireless 
connection and may not have a user interface. CLDC devices use the K-Java Virtual Machine 
(KVM) implementation, which is a stripped-down9 version of the JVM. CLDC devices 
include pagers, personal digital assistants, cell phones, dedicated terminals, and 
handheld consumer devices with between 128KB and 512KB of memory. '? CDC devices use 
a 32-bit architecture, have at least two megabytes of memory available, and implement a 
complete functional JVM. CDC devices include digital set-top boxes, home appliances, 


navigation systems, point-of-sale terminals, and smart phones. 
3. J2ME profile 


A profile consists of Java classes that enable implementation of features for either a 
particular small computing device or for a class of small computing devices. Small 
computing technology continues to evolve, and with that, there is an ongoing 9 process of 
defining J2ME profiles. Seven profiles have been defined as of this writing. These are the 
Foundation Profile, Game Profile, Mobile Information Device Profile, PDA 
Profile Personal Profile, Personal Basis Profile, and RMI Profile®. 

The Foundation Profile is used with the CDC configuration and is the core for® nearly 
all other profiles used with the CDC configuration because the Foundation Profile contains 
core Java classes. 

e The Game Profile is also used with® the CDC configuration and contains the 


necessary classes for developing game applications for any small computing device 
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that uses the CDC configuration. 


* The Mobile Information Device Profile ( MIDP) is used with the CLDC configuration 
and contains classes that provide local storage®, a user interface, and networking 


capabilities? to an application that runs on a mobile computing device such as 
Palm OS devices. MIDP is used with wireless Java applications. *¥ 
e The PDA Profile ( PDAP) is used with the CLDC configuration and contains classes 


that utilize9 sophisticated resources" found on personal digital assistants. These 


features include better displays and larger memory than similar resources found on 
MIDP mobile devices ( such as cell phones). E 

* The Personal Profile is used with the CDC configuration and the Foundation Profile 
and contains classes to implement a complex user interface. The Foundation Profile 
provides core classes, and the Personal Profiles provide classes to implement a 
sophisticated user interface, which is a user interface that is capable of displaying 
multiple windows at a time. 

e The Personal Basis Profile is similar to the Personal Profile in that it is used with the 
CDC configuration and the Foundation Profile. However, the Personal Basis Profile 
provides classes to implement a simple user interface, which is a user interface that is 
capable of displaying one window at a time. 

* The RMI Profile is used with the CDC configuration and the Foundation Profile to 
provide Remote Method Invocation classes to the core classes contained in the 
Foundation Profile. 

There will likely be many profiles as the proliferation of small computing devices 
continues. Industry groups within the Java Community Process Program ( java. sun. com/ 
aboutjava/communityprocess) define profiles. Each group establishes the standard profile 
used by small computing devices manufactured by that industry. A CDC profile is defined by 
expanding9 upon core Java classes found in the Foundation Profile with classes specifically 
targeted to a class of small computing device. These device-specific classes are contained in a 
new profile that enables developers to create industrial-strength9 applications for those 
devices. However, if the Foundation Profile is specific to CDC, not all profiles are expanded 
upon the core classes found in the Foundation Profile. 

Keep in mind that applications can access a small computing device's software and 


hardware features only if the necessary classes to do so are contained in the JVM and in the 


profile used by the developerE 


存储 
能 力 
利用 
扩展 
工业 级 强度 
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Words 


breed n. (名 词 ) [生物 ] 品种 ;种 类 ,类 型 
capabilities n. (名 词 ) 能 力 (capability 的 复数 ) ;功能 ;性 能 
continuity n. (名 词 ) 连续 性 ;一 连 串 ;分 镜头 剧本 
dedicate adj. (形容 词 ) 专用 的 ;专注 的 ;献身 的 
evolve vt. &vi. (动词 ) 发 展 ,进化 ;使 逐步 形成 ;推断 出 
expand vt. &vi. (动词 ) 扩大 ,扩展 (expand 的 现在 分 词 形式 ); 使 膨 
胀 , 详 述 
formidable adj. (形容 词 ) 可 怕 的 ; 令 人 冤 情 的 ;艰难 的 ;强大 的 
handheld adj. (形容 词 ) 掌上 型 ;手持 型 
navigation n. (名 词 ) 导航 
ongoing adj. (形容 词 ) 即将 
storage n. (名 词 ) 存储 ;仓库 ;贮藏 所 
terminals n. (名 词 ) 终端 ;终端 机 
wireless adj. (形容 词 ) 无 线 的 ;无 线 电 的 
Phrases 
charged with 承担 ,负责 
core for 核心 
Foundation Profile 基础 配置 文件 
Game Profile 游戏 配置 文件 
industrial-strength 工业 级 强度 ;工业 级 
Java Community Process Program Java 社团 处 理 程序 
memory availability 内 存 可 用 性 
Mobile Information Device Profile 移动 信息 装备 配置 文件 
PDA Profile 个 人 助理 配置 文件 
Personal Basis Profile 个 人 基本 信息 配置 文件 
Personal Profile 个 人 配置 文件 
point-of-sale terminals (计算 机 ) 销 售 点 终端 机 
RMI Profile RMI 配置 文件 
set-top boxes dL TR es 
stripped-down 简装 的 
used with 使 用 


x, m 


批 注 

注 1 及 ME 为 主语 ; 谓 场 : must service;including screen phones, digital set-top boxes used for cable 
television, cell phones, and personal digital assistants. 为 分 词 结构 ;used for cable television, cell phones, 
and personal digital assistants 是 后 置 定 语 , 修 饰 boxes, 

注 2 短语: One;the other: 是 对 two configurations 的 补充 说 明 。 

注 3 主语 : CLDC devices; 谓 语 : use; 宾 语 : (KVM) implementation, which 引导 一 个 非 限制 性 定语 
Mj, 

注 4 主语 : MIDP; 两 个 并 列 谓语 : is 和 contains; That provides 3X] JJ 4E i8 A ^n] ,先行 词 是 classes; 
that runs 这 人 句 为 主语 从 名 ,先行 词 是 application, 

ib5 这 是 一 个 比较 名 ,better,larger than ,found 为 分 词 结构 作 和 定语 ,修饰 resources, 

ik6 Keep in mind 这 个 短语 作 主 语 ; 谓 语 : can access;only if 引导 一 个 条 件 状 语 从 名 ;in the JVM 
与 in the profile 并 列 ;used by the developer 作 定 语 ,修饰 the profile, 


Associated Reading 


C 单 见报 铺 及 其 含义 
不 明确 的 运算 需要 用 括号 括 起 来 


Ambiguous operators need parentheses 


Ambiguous symbol "xxx" 

Argument list syntax error 

Array bounds missing 

Array size too large 

Bad character in parameters 

Bad file name format in include directive 
Bad ifdef directive syntax 

Bad undef directive syntax 

Bit field too large 

Call of non-function 

Call to function with no prototype 
Cannot modify a const object 

Case outside of switch 

Case syntax error 

Code has no effect 

Compound statement missing | 
Conflicting type modifiers 

Constant expression required 
Constant out of range in comparison 
Conversion may lose significant digits 


Could not find file "xxx" 


s d a 


"xxx" f] AA XE 
参数 列表 语法 错误 
丢失 数组 界限 符 
数组 太 大 
参数 中 有 无 效 的 字符 


编译 预 处 理 中 的 文件 名 格式 不 正确 


编译 预 处 理 ifdef 语法 错 
编译 预 处 理 undef 语法 钳 
位 字段 太 长 

Hal FA AR XE XB ERE 

调用 无 原型 声明 的 图 数 
不 允许 修改 第 量 对 象 
case 语句 在 switch 外 
case 语法 错误 
代码 不 起 作用 

复合 语句 漏 抒 "| ” 

不 明确 的 类 型 说 明 符 

在 比较 中 篆 量 超出 范围 
转换 时 会 丢失 有 将 数字 位 
找 不 到 "xxx" 文 件 


Declaration missing ; 

Default outside of switch 

Define directive needs an identifier 
Division by zero 

Do statement must have while 
Enum syntax error 

Enumeration constant syntax error 
Error directive :XXX 

Error writing output file 
Expression syntax error 

Extra parameter in call 

File name too long 
Function call missing" |” 

Function definition out of place 

Function should return a value 

Goto statement missing label 

Hexadecimal or octal constant too large 
Illegal character "x" 

Illegal initialization 

Illegal octal digit 

Illegal pointer subtraction 

Illegal structure operation 

Illegal use of floating point 

Illegal use of pointer 

Improper use of a type def symbol 

In-line assembly not allowed 

Incompatible storage class 

Incompatible type conversion 

Incorrect number format 

Incorrect use of default 

Invalid pointer addition 

Logical value required 

Macro argument syntax error 

Macro expansion too long 

Mismatched number of parameters in definition 
Misplaced break 

Misplaced continue 


Misplaced decimal point 


PiBp p" ;” 


default 出 现在 switch 语句 之 外 
定义 编 详 预 处理 需 要 标识 符 


用 0 作 除 数 


do-while 语句 中 缺少 while 部 分 


枚 举 类 型 语法 错误 
枚 举 常数 语法 错误 


错误 的 编译 预 处 理 信 令 "; xxx" 


写 输 出 文件 错误 
表达 式 语 法 错误 
调用 时 出 现 多 余 参数 
文件 名 太 长 
函数 调用 缺少 右 插 号 
PATE Ci FR 
PRIA > ZH [6] —“ [EL 
Goto 语句 没有 标号 


十 六 进 制 或 八进制 常数 太 大 


非法 字符 "x" 
非法 的 初始 化 
非法 的 八进制 数字 
非法 的 指针 相 减 

非法 的 结构 体操 作 
非法 的 浮 点 运算 
指针 使 用 非法 

类 型 定义 符号 使 用 不 恰当 
不 允许 使 用 行 汇 编 舱 入 
存储 类 别 不 相 容 

不 相 容 的 类 型 转换 
错误 的 数据 格式 

default 使 用 不 当 

指针 相 加 无 效 

宏 参 数 语法 错误 

宏 扩展 后 太 长 

定义 中 参数 个 数 不 匹 配 
此 处 不 应 出 现 break 语句 
此 处 不 应 出 现 continue 语句 
此 处 不 应 出 现 小 数 点 


Misplaced elif directive 

Misplaced else 

Misplaced else directive 

Misplaced endif directive 

Must be addressable 

Must take address of memory location 
No declaration for function "xxx" 

No stack 

No type information 

Not a valid expression format type 
Not an allowed type 

Numeric constant too large 

Out of memory 

Parameter "xxx" is never used 
Pointer required on left side of — > 
Possible use of "xxx" before definition 
Possibly incorrect assignment 
Re-declaration of "xxx" 

Redefinition of "xxx" is not identical 
Register allocation failure 

Repeat count needs an | value 

Size of structure or array not known 
Statement missing ; 

Structure or union syntax error 
Structure size too large 

Sub scripting missing | 

Superfluous & with function or array 
Suspicious pointer conversion 
Symbol limit exceeded 

Too few parameters in call 

Too many default cases 

Too many error or warning messages 
Too many type in declaration 

Too much global data defined in file 
Two consecutive dots 

Type mismatch in parameter "xxx" 
Type mismatch in re-declaration of "xxx" 


Unable to create output file "xxx" 


A y 


elif 指令 位 置 错 

此 处 不 应 出 现 else 

此 处 不 应 出 现 编译 预 处 理 else 
此 处 不 应 出 现 编译 预 处 理 endif 
必须 是 可 以 编 址 的 
必须 存储 定位 的 地 址 

1x8 ERU xxx" BJ à AA 
没有 类 型 信息 

不 合法 的 表达 式 格式 

不 允许 使 用 的 类 型 

常量 数值 太 大 

超出 内 存 范 围 

参数 "xxx" 没 有 用 到 

符号 -> 的 左边 必须 是 指针 
在 定义 之 前 使 用 了 "xxx" 
赋值 可 能 不 正确 

重复 定义 了 "xxx" 

没有 用 到 参数 "xxx" 
重复 计数 需要 人 逻辑 值 1 

结构 体 或 数组 大 小 不 确定 
语句 后 缺少 ;” 

结构 体 或 联合 体 语法 错误 
结构 体 尺 寸 太 大 

下 标 缺 少 " ] ” 

PRAACH PA ZRH“ 
可 疑 的 指针 转换 

ITS EPR 

PR ZU] HY AY SBE ARGE SLA IB S 
default KÉ ( switch 语句 中 一 个 ) 
错误 或 警告 信息 太 多 
声明 中 的 类 型 太 多 

文件 中 的 全 局 数据 太 多 
两 个 连续 的 句点 

参数 xxx'" 类 型 不 匹配 

xxx" 壬 定义 的 类 型 不 匹配 
无 法 建立 输出 文件 xxx" 


Unable to open include file "xxx" 

Unable to open input file "xxx" 

Undefined label "xxx" 

Undefined structure "xxx" 

Undefined symbol "xxx" 

Unexpected end of file in comment 
started on line xxx 

Unexpected end of file in conditional 
started on line xxx 

Unknown assemble instruction 

Unknown option 

Unreachable code 

User break 

Void functions may not return a value 

Wrong number of arguments 

XXX not an argument 


"xxx" not part of structure 


无 法 打开 被 包含 的 文件 "Xxx" 

无 法 打开 输入 文件 "xxx" 

没有 定义 的 标号 "XXX" 

没有 定义 的 结构 体 "xxx" 
没有 定义 的 符号 "XXX" 

源 文件 在 xxx 行 开 始 的 注释 中 意外 结束 


源 文件 在 xxx 行 开 始 的 条 件 语句 中 意外 结束 


未 知 的 汇编 结构 

未 知 的 选项 

执行 不 到 的 代码 

用 户 强行 中 断 

void 类 型 的 函数 不 应 有 返回 值 
调用 函数 的 参数 个 数 错 
xxx" 不 是 参数 

xxx" 不 是 结构 体 的 一 部 分 


ee 


Unit3 Discrete Mathematic 


Text A About Discrete Mathematic 


1. Introduction to discrete mathematics 


Discrete9 Mathematics is the general term® for several branches of mathematics, 
which is based on the study of mathematical structures that are fundamentally discrete rather 


than continuous. In contrast to® real numbers that have the property9 of varying 


"smoothly", the objects studied in discrete mathematics-such as integers, graphs, and 


statements in logic-do not vary smoothly in this way, but have distinct9, separated 


注 1 


values. Discrete mathematics therefore excludes topics in “ continuous 


mathematics®” such as calculus® and analysis. Discrete objects can often be 
enumerated® by integers. More formally, discrete mathematics has been characterized as 
the branch of mathematics dealing with countable sets® ( sets that have the same 
cardinality® as subsets® of the integers, including rational® numbers but not real 
numbers). However, there is no exact, universally agreed, definition of the term " discrete 
mathematics. " Indeed, discrete mathematics is described less by what is included than® by 
what is excluded; continuously varying quantities and related notions. 

Research in discrete mathematics increased in the latter half of the twentieth century 


partly due to the development of digital computers which operate in discrete steps and store 


离散 的 
一 般 术 语 
相反 地 
性 质 , 性 能 
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微 积 分 学 
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概念 


UJ 
Ñ 


data in discrete bits. Concepts and notations from discrete mathematics are useful in 
studying and describing objects and problems in branches of computer science, such as 
computer algorithms®, programming languages, cryptography®, automated theorem 
proving, and software development. Conversely9, computer implementations9 are 


significant. 
2. Topics in discrete mathematics 


Theoretical computer science includes areas of discrete mathematics relevant to 
computing. It draws heavily on graph theory and logic. Included within theoretical computer 
science is the study of algorithms for computing mathematical results. Computability9 
studies what can be computed in principle, and has close ties to logic, while complexity 
studies the time taken by computations. Automata theory and formal language theory are 
closely related to computability. Computational geometry applies algorithms to 
geometrical® problems, while computer image analysis applies them to representations of 
images. Theoretical computer science also includes the study of various continuous 
computational topics. 

Logic is the study of the principles of valid reasoning and inference9, as well as® of 
consistency soundness9, and completeness9. For example, in most systems of logic 
( but not in intuitionistic logic®) Peirce’s law ( ((POGQ) —P)—P) is a theorem. For 
classical logic, it can be easily verified® with a truth table. The study of mathematical proof 


is particularly important in logic, and has applications to automated theorem proving and 
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formal verification of software. 

Logical formulas are discrete structures, as are proofs, which form finite trees or, more 
generally, directed acyclic graphstructures9 ( with each inference step combining one or 
more premise branches to give a single conclusion). The truth values of logical formulas 
usually form a finite set, generally restricted to two values; true and false, but logic can also 
be continuous-valued, e. g. , fuzzy logic. Concepts such as infinite proof trees or infinite 
derivation9 trees have also been studied, e. g. infinitary logic. 

Set theory is the branch of mathematics that studies sets, which are collections of 
objects, such as | blue, white, red} or the (infinite) set of all prime numbers. Partially9 
ordered sets and sets with other relations have applications in several areas. 

In discrete mathematics, countable sets ( including finite sets) are the main focus. The 
beginning of set theory as a branch of mathematics is usually marked by Georg Cantor's work 
distinguishing between different kinds of infinite. set, motivated. by the study of 
trigonometric series®, and further development of the theory of infinite sets is outside the 
scope of® discrete mathematics. '? Indeed, contemporary work in descriptive set theory 
makes extensive use of traditional continuous mathematics. 

Graph theory, the study of graphs and networks, is often considered part of 
combinatory, but has grown large enough and distinct enough, with its own kind of 
problems, to be regarded as® a subject in its own right Which in all areas of€ math and 
science have extensive application. 

Graphs are one of the prime objects of study in Discrete Mathematics. They are among 
the most ubiquitous® models of both natural and human-made structures. They can model 
many types of relations and process dynamics in physical, biological and social systems. In 
computer science, they represent networks of communication, data organization, 
computational devices, the flow of computation, etc. In Mathematics, they are useful in 


Geometry and certain parts of topology9, e. g. Knot Theory. Algebraic graph theory 
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has close links with group theory. There are also continuous graphs, however for the most 
part research in graph theory falls within the domain9 of discrete mathematics. 

Operations research provides techniques for solving practical problems in business and 
other fields—problems such as allocating resources to maximize profit, or scheduling project 
activities to minimize risk. Operations research techniques include linear programming and 
other areas of optimization®, queuing theory, scheduling theory, network theory. 
Operations research also includes continuous topics such as continuous-time Markov 
process®, continuous-time martingales®, process optimization, and continuous 
and hybrid control theory. 

Although topology is the field of mathematics that formalize® and generalizes the 
intuitive9 notion of “continuous deformation" of objects, it gives rise to many 
discrete topics; this can be attributed in part to the focus on topological invariants, which 
themselves usually take discrete values. See combinatorial topology®, topological 
graph theory9, topological combinatorics®, computational topology®, discrete 
topological space®, finite topological space. 


Words 


algorithm n. (名 词 ) 算法 ;算法 式 (algorithm 的 复数 ) 
automate adj. (形容 词 ) 自动 化 的 ;机 械 化 的 

bit n. (名词 ) 比特 ,位 

calculu n. (名 词 ) 结石 ; 微 积分 学 

cardinality n. (4 ig) HR; RNS 

computability n. (474) 可 计算 性 

conversely adv. (副词 ) 相反 地 


领域 

优化 

连续 时 间 马 尔 可 夫 过 程 
ESE AY [n] BR 

过 程 优化 及 连续 混合 控制 理论 
形式 化 

一 般 化 

直觉 

连续 变形 

组 合 拓扑 

拓扑 图 论 

拓扑 组 合 

计算 拓扑 

离散 空间 

有 限 拓扑 空间 
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cryptography n. (名 词 ) 密码 学 ;密码 使 用 法 

derivation n. (名 词 ) 引出 ;来 历 ; 词 源 

discrete adj. (形容 词 ) 离散 的 ,不 连续 的 

distinct adj. (形容 词 ) 明显 的 ;独特 的 ;清楚 的 ;有 区 别 的 

domain n. (名 词 ) 领域 ;域名 ;产业 ;地 产 

enumerate n. (名 词 ) 枚 举 类 型 

exclude vt. &vi. (动词 ) 排除 ;排斥 ;拒绝 接纳 ; 逐 出 

formalize vt. &vi. (动词 ) 使 形式 化 ;使 正式 ;拘泥 礼仪 

generalize vt. &vi. (动词 ) 概括 ;推广 ;使 .…… 一 般 化 

geometrical adj. (形容 词 ) 几何 的 ,几何 学 的 

hybrid n. (名 词 ) 混合 

implementation n. (名 词 ) 实施 

inference n. (名 词 ) 推理 ;推论 ;推断 

intuitive adj. (和 形容词) 直觉 的 ; 赁 直觉 获知 的 

notation n. (名 词 ) 符号 ; 记 法 

notion n. (名 词 ) 观念 ;小 商品 

object n. (名 词 ) 物体 ; 对象 

optimization n. (名 词 ) 最 佳 化 ,最 优化 

partially adv. (副词 ) 部 分 地 ; 偏 祖 地 

premise vt. & vi. (动词 ) 引出 ,预先 提出 ;作为 ……… 的 前 提 

property n. (474) 性 质 ,性 能 ;财产 ;所 有 权 

rational adj. (和 形容词) 合理 的 ;理性 的 

subsets n. (名 词 ) 子 集 合 ( subset 的 复数 ) 

theorem n. (名 词 ) 定理 原理 

topology n. (名 词 ) 拓扑 学 ;地 质 学 ;局 部 解剖 学 

ubiquitous adj. (形容 词 ) 普遍 存在 的 ;无 所 不 在 的 

verification n. (名 词 ) 确认 ,查证 ;核实 

verified adj.( 形容词) 已 查 清 的 ,已 证 实 的 
Phrases 

as well as 也 ;和 .……: 一 样 ;不 但 ……… 而 且 

be regarded as 被 认为 是 ;被 当 作 是 

combinatorial topology 组 合 拓 扑 学 ;组 合 拓 扑 

complexity studies 复杂 性 研究 

computational topology 计算 拓扑 

consistency soundness 一 致 性 ,可 靠 性 

contemporary work 当代 作品 
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continuous deformation 连续 形变 


continuous mathematics 连续 数学 
continuous-time Markov process 连续 时 间 的 马尔 可 夫 过 程 
continuous-time martingales 连续 时 间 蒜 
countable sets DE €: 
directed acyclic graphstructures 有 向 无 环 图 结构 
discrete topological space 离散 拓扑 空间 
distinct enough 截然 不 同 
finite topological space 有 限 拓扑 空间 
in all areas of 在 各 方面 的 
in branches of ah x Bj 
in contrast to 相 比 之 下 
intuitionistic logic EW EAF H 
knot theory 结 点 理论 ;[ 数 ] 纽 结 理论 
the general term for 一 般 的 术语 
the scope of 范围 
topological combinatorics 拓扑 组 合 
topological graph theory 图 论 拓扑 
trigonometric series 三 角 级 数 
Exercises 


[Ex1] Answer the questions according to the text: 


(1) What is Discrete Mathematic? 

(2) Why did Discrete Mathematic develop so fast in the twentieth century? 
(3) How many topics are there in this chapter,and what are they? 

(4) What are the logic formulas? 


(5) What does Operations research involve? 
[Ex2] Translate into Chinese: 


(1) Graph theory is an old subject with modern applications. 

(2) Relation between elements of sets is represented using the structure called a 
relation. 

(3) Much of discrete mathematic is developed of discrete structures, which are used to 
represent discrete objects. 

(4) Discrete mathematic is the gateway to more advanced courses in all parts of the 


mathematical sciences. 
; 30% 


(5) The computer chip is primarily responsible for executing instructions. 

(6) Tape must be read or written sequentially, not randomly. 

(7) Deselect the text by clicking anywhere outside of the selection on the page or 
pressing an arrow key on the keyboard. 

(8) Faster than many types of parallel port, a single USB port is capable of chaining 


many devices without the need of a terminator. 
[Ex3] Choose the best answer: 


(1) Very long, complex expressions in program are difficult to write correctly and 
difficult to 
A. defend B. detect C. default D. debug 


(2) is the study of the principles of valid reasoning and inference, as well as 


of consistency, soundness, and completeness. 


A. Graph theory B. Logic 
C. Topology D. Operation research 
(3) The storage area that you can use to copy or move selected text or object 


among applications. 
A. exponent B. order C. temporary D. superior 
(4) Software design is a process. It requires a certain of flair on the 
part of the designer. 
A. create , amount B. created , amounted 


C. creating , mount D. creative , mounted 


批 注 
注 1 In contrast to 短语 引导 的 独立 结构 ;that have the property of varying “smoothly” A c £7 i5] 2J 
real numbers , JS 4 14 A. h] ; the objects 为 句子 的 主语 ;studied 为 谓语 ;do not vary smoothly in this way, but 
have distinct, separated values. 补充 说 明 。 
注 2 The beginning of set theory 为 主语 ; as a branch of mathematics 为 方式 状语 ; is marked, 


motivated , and further development of the theory of infinite sets 为 句子 谓语 。 


Text B Tree 


A connected graph shown in Figure 3-1, that contains no simple circuits is called 


a tree. Trees were used as long ago as 1857, when the English mathematician Arthur Cayley 


@ 连通 图 
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used them to count certain types of chemical compounds 9. Since that time, trees have 
been employed to solve problems in a wide variety of9 disciplines. 


a b 
d ; d C 
C d 
e f e f 
G, G, G4 G, 


Figure 3-1 Graphs 


Tree are particularly useful in computer science, for instance, trees are employed to® 
construct efficient algorithms for locating items in a list. They are used to construct 
network with the least expensive set of telephone lines storing and transmitting9 data. ™ 
Trees can model procedures that are carried out® using a sequence of decisions. This 
makes trees valuable in the study9 of sorting algorithms. 


1. Definitions 


A tree is an undirected simple graph G that satisfies any of the following equivalent 


conditions? 。 


* G is connected and has no cycles. 

e G has no cycles, and a simple cycle is formed if any edge is added to G. 

* G is connected, and it is not connected anymore if any edge is removed from G. 

* G is connected and the 3-vertex complete graph K, is not a minor of G. di 

e Any two vertices in G can be connected by a unique simple path. 

If G has finitely many vertices, say n of them, then the above statements are also 
equivalent to any of the following conditions: 

* G is connected and has (n —1) edge. 


e G has no simple cycles and has (n —1) edge. 
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Which of the graphs shown in Figure 3-1 are trees? 
G, and G, are trees, since both are connected graphs with no simple circuits; G, is not a 
tree because e. b.a.d.e is a simple circuit. ™ 


In this graph. Finally, G, is not a tree since it is not connected. 
2. Facts 


(1) A tree with n vertices has (n —1) edges. 

(2) A full m-ary tree with i internal vertices contains n =m * i +1 vertices. 

(3) A full m-ary tree with. 

(i) n vertices has i = (n — 1)/m internal vertices and L 2 |(m —1) *n+1]|/m 
leaves. 

(ii) i internal vertices has n =m * i + 1lvertices and L— (m —1) * i41 leaves. 

(iii) L leaves has n =(m * L—1)/(m-—1) vertices and i = (L—1)/(m —1) internal 


vertices. 
3. Tree spices 


(1) M-ary tree is a tree with the property that every internal vertex® has no more than 
m children. 

(2) Binary tree is an m-ary tree with m =2( each child may be designated as a left or a 
right child of its parent). 

(3) Ordered tree is a tree in which the children of each internal vertex are linearly 
ordered. ^? 

(4) Balance tree is a tree in which every vertex is at level h or h-1. where h is the height 
of the tree. *° 

(5) Binary search tree is a binary tree in which the vertices are labeled with items so 
that® a label of a vertex is greater than the labels of all vertices in the left subtree of this 
vertex is an less than the label of all vertices in the right sub tree of this vertex. 

(6) Decision tree is a rooted tree where each vertex represents a possible outcome of a 
decision and the leaves represent the possible solutions. 

(7) Spanning tree®, a tree containing all vertices of a graph. 


(8) Minimum spanning tree®, a spanning tree with smallest possible sum of 


weights of its edges. * 
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4. Tree traversal algorithms 


Procedures for systematically visiting every vertex of an ordered rooted tree are called 
traversal algorithms. We will describe three of the most commonly used such algorithms 
preorder traversal, inorder traversal, and postorder traversal. 

(1) Preorder traversal 

Preorder traversal® is listing of the vertices of an ordered rooted tree defined 
recursively by specifying that the root is listed. Followed by the first subtree, followed by the 
other sub trees in the order they occur from left to right. 

Let T be an ordered rooted tree with root r. if T consists only of r, then r is the preorder 
traversal of T. Otherwise, suppose that 7,,7,,--:, T, are the sub trees® at r from left to 
right in T. The preorder traversal begins by visiting r. It continues by traversing T, in 
preorder, then T, in preorder, and so on, until T, is traversed in preorder. 

(2) Inorder traversal 

Inorder traversal® is a listing of® the vertices of an ordered rooted tree defined 
recursively by® specifying that the first sub tree is listed followed by® the root, followed by 
the other sub trees in the order they occur from left to right. 

Let T be an ordered rooted tree with root r. if T consists only of r, then r is the inorder 
traversal of T. Otherwise, suppose that T, ,7,,--:, T,. are the subtrees at r from left to right 
in T. The inorder traversal begins by traversing T, in inorder. Then visiting r, It continues by 
traversing T, in inorder, then T, in inorder, ---, And finally T, in inorder. 

(3) Postorder traversal 

Postorder traversal® is a listing of the vertices of an ordered rooted tree defined 
recursively by specifying that the sub trees are listed in the order they occur from left to right, 
followed by the root. ™ 

Let T be an ordered rooted tree with root r if T consists only of r, then r is the post order 
traversal of T. Otherwise, suppose that T, ,7,,--:,7.,. are the subtrees at r from left to right. 
The postorder traversal begins by traversing T, in postorder, then T, in postorder, ---, Then 


T,. in postorder, and ends by visiting r. 


遍历 算法 
前 序 遍 历 
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中 序 遍 历 
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Words 


circuit n. (名 词 ) 电路 ; 环 路 ;巡回 

compound vt. & vi. (动词 ) Ms HA TU E XC V BAH 

connected graph n. (474) 连接 图 ,| 数 ] 连 通 图 

discipline n. (名 词 ) 纪律 

equivalent adj. (形容 词 ) 等 价 的 ,相等 的 ; 同意 义 的 

inorder traversal n. (名 词 ) 中 序 遍 历 

internal n. (名 词 ) 内 部 的 ;内 在 的 ;国内 的 

item n. (名 词 ) 项 目 ;名 目 ; 所 有 物品 

preorder traversal n. (名 词 ) 先 序 遍 历 

transmitting vt. &vi. (动词 ) 传说 ,发射 

vertex n. (名 词 ) TA EJAM; [A] AM 

vertice n. (名 词 ) 制高点 ;天 顶 ; 头 顶 
Phrases 

be carried out 进行 

be employed to 用 来 

defined by 定义 为 

followed by 紧 随 其 后 

in a wide variety of 各 种 各 样 的 

in the study 在 这 项 研究 中 


批 注 
注 1 storing and transmitting data 用 于 修饰 network, 作 定语 。 此 句 话 的 含义 是 : 他 们 用 花 销 代价 最 
少 的 电话 线 构建 网 络 ,用 它 来 存储 ,传输 数据 。 
注 2 ”此 句 话 的 含义 是 : 一 个 树 是 一 个 无 回 简单 图 G, 它 满足 以 下 任何 等 价 条件 。 
注 3 G 是 连通 的 ,3 个 顶点 构成 了 图 K , 它 不 是 一 个 G 图 的 镜像 图 。 
注 4 AG, 和 图 G, 是 树 ,因为 它们 都 是 有 向 图 ,没有 回路 的 有 向 图 ,而 图 G, 不 是 树 ,因为 ebade 是 
一 个 简单 的 回路 。 
注 5 主 霹 : Ordered tree; 系 动词 : is;in which 引导 一 个 定 霹 从 句 ;the children 为 定 从 的 主语 ;are 
ordered 是 定 从 的 谓语 。 这 人 句 话 的 含义 是 : 有 序 树 是 它 的 内 部 子 顶 点 都 是 线性 地 排序 的 树 。 
ibo 主场 : Balance tree; 系 动词 : is;in which 引导 一 个 定语 从 名 ;every vertex 为 从 句 的 主语 。 这 何 
话 的 含义 是 : 平衡 树 是 它 的 每 个 项 点 都 在 h 或 h-1 层 , 而 h 是 该 树 的 高 度 。 
注 7 最 小 生成 树 : 它 的 边 权 总 数 为 最 小 的 树 。 
注 8 H, Postorder traversal; 谓语 : is; 表 语 : a listing of the vertices of an ordered rooted tree;by 54| 
导 状 语 主语 。 
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Associated Reading 


Topics in Discrete Mathematics 


Discrete mathematics is the study of mathematical structures that are fundamentally 
discrete rather than continuous. The main topics in discrete mathematics have as the 
following : 

(a) Theoretical computer science 

(b) Information theory 

(c) Logic 

(d) Set theory 

(e) Combinatorics 

(f) Graph theory 

(g) Probability 

(h) Number theory 

(1) Algebra 

(j) Calculus of finite differences, discrete calculus or discrete analysis 

(k) Geometry 

(1) Topology 

(m) Operations research 

(n) Game theory, decision theory, utility theory, social choice theory 

(0) Discretization 

(p) Discrete analogues of continuous mathematics 

(q) Hybrid discrete and continuous mathematics 

相关 离散 数学 主题 : 

(a) 理论 计算 机 科学 

(b) 信息 论 

(c) 逻辑 学 

(d) 集合 论 

(e) 组 合 数学 

(f) 图 论 

(g) 概率 论 

(h) 数论 

(i) 代数 

(j) 差分 演算 ,离散 模型 符号 验证 或 者 离散 分 析 

(k) 几何 学 

(1) 拓扑 学 

ALT 


(m) 运筹 学 

(n) 博弈 论 .决策 论 ,效用 理论 ,社会 选择 理论 
(o) 离散 化 

(p) 连续 数学 的 离散 近似 

(q) 离散 和 连续 混合 数学 
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Unit4 Software Engineering 


Text A Software Processes 


A software process is a set of activities that leads to the production of a software 
product. These activities may involve the development of software from scratch in a 
standard programming language like Java or C. Increasingly, however, new software is 
developed by extending and modifying existing systems and by configuring9 and 
integrating® off-the-shelf software or system components. *¥' 

Software processes are complex and, like all intellectual and creative processes, rely 
on people making decisions and judgments. Because of the need for judgment and 
creativity, attempts to automate® software processes have met with limited success. 
Computer-aided software engineering ( CASE) tools can support some process activities. 
However, there is no possibility, at least in the next few years, of more extensive 
automation where software takes over9 creative design from the engineers involved in the 
software process. ? 

One reason the effectiveness of CASE tools is limited is because of the immense® 
diversity of software processes. There is no ideal process, and many organizations have 
developed their own approach to software development. Processes have evolved to exploit the 
capabilities of the people in an organization and the specific characteristics of the systems that 
are being developed. For some systems, such as critical systems, a very structured 
development process is required. For business systems, with rapidly changing requirements , 
a flexible, agile process is likely to be more effective. 

Although there are many software processes, some fundamental activities are 


common to all software processes: 
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(1) Software specification the functionality of the software and constraints? on its 
operation must be defined. 

(2) Software design and implementation the software to meet the specification 
must be produced. 

(3) Software validation the software must be validated to ensure that it does what 
the customer wants. 

(4) Software evolution the software must evolve to meet changing customer needs. 

Although there is no ‘ ideal’ software process, there is scope® for improving the 
software process in many organizations. Processes may include outdated techniques or may 
not take advantage of the best practice in industrial software engineering. Indeed, many 
organizations still do not take advantage of software engineering methods in their 
software development. 

Software processes can be improved by process standardization where the diversity in 
software processes across an organization is reduced. This leads to improved communication 
and a reduction in training time, and makes automated process support more economical. 
Standardization is also an important first step in introducing new software engineering 


methods and techniques and good software engineering practice. 
Software process models 


A software process model is an abstract representation of a software process. Each 
process model represents a process from a particular perspective, and thus provides only 
partial? information about that process. * In this section, I introduce a number of very 
general process models (sometimes called process paradigms®) and present these from an 
architectural perspective9. That is, we see the framework of the process but not the 
details of specific activities. 

These generic models are not definitive® descriptions of software processes. 


Rather, they are abstractions of the process that can be used to explain different approaches to 
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software development. You can think of them as process frameworks that may be 
extended and adapted to create more specific software engineering processes. te 


(1) The waterfall model® this takes the fundamental process activities of 


specification, development, validation and evolution and represents them as separate process 
phases® such as requirements specification®, software design, implementation, testing 
and so on. * 

(2) Evolutionary development9 this approach interleaves9 the activities of 
specification, development and validation. An initial system is rapidly developed from 
abstract specifications. This is then refined with customer input to produce a system that 
satisfies the customer's needs. 

(3) Component-based software engineering this approach is based on the 
existence of a significant number of reusable components. The system development process 
focuses on integrating these components into a system rather than developing them from 
scratch. 

The waterfall model 

The first published model of the software development process was derived from more 
general system engineering processes ( Royce, 1970). This is illustrated in Figure 4-1. 
Because of the cascade from one phase to another, this model is known as the waterfall 
model or software life cycle. The principal stages of the model map onto fundamental 
development activities : 

i. Requirements analysis and definition the system's services, constraints and 
goals are, established by consultation with system users. They are then defined in 
detail and serve as9 a system specification. 

ii. System and software design the systems design process partitions the 
requirements to either hardware or® software systems. It establishes overall system 


architecture. Software design involves identifying and describing the fundamental software 
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Requirements 
definition 
System and 
software design 
Implementation 
and unit testing 
Integration and 
system testing 
Operation and 
maintenance 


Figure 4-1] The software life cycle 


system abstractions and their relationships. 

iii. Implementation and unit testing during this stage, the software design is 
realized as a set of programs or program units. Unit testing involves verifying that each 
unit meets its specification. 

iv. Integration and system testing the individual program units or programs are 
integrated and tested as a complete system to ensure that the software requirements have been 


met. After testing, the software system is delivered to the customer. 总 


v. Operation and maintenance9 normally ( although not necessarily) this is the 
longest life-cycle phase®. The system is installed and put into practical use. Maintenance 
involves correcting errors which were not discovered in earlier stages of the life cycle, 
improving the implementation of system units and enhancing the system’s services as new 
requirements are discovered. i 

In principle, the result of each phase is one or more documents that are approved 
( * Signed off’ ). The following phase: should not start until the previous phase has finished. 
In practice, these stages overlap® and fleed information to® each other. $$ During design, 
problems with requirements are identified; During coding design problems are found and so 
on®. The software process is not a simple linear model but involves a sequence of 
iterations of the development activities. 


Because of the costs of producing and approving documents, iterations are costly and 
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involve significant rework9. Therefore, after a small number of iterations, it is normal to 
freeze parts of the development, such as the specification, and to continue with the later 
development stages. ? Problems are left for later resolution, ignored or programmed around. 
This premature freezing of requirements may mean that the system won't do what the user 
wants. It may also lead to badly structured systems as design problems are circumvented 
by® implementation tricks®. 

During the final life-cycle phase ( operation and maintenance) , the software is put into 
use. Errors and omissions® in the original software requirements are discovered. Program 
and design errors emerge and the need for new functionality is identified. The system must 
therefore evolve to remain useful. * Making these changes ( software maintenance) may 
involve repeating previous process stages. 

The advantages of the waterfall model are that documentation is produced at each phase 
and that it fits with other engineering process models. Its major problem is its inflexible® 
partitioning of the project into distinct stages. Commitments® must be made at an early 
stage in the process, which makes it difficult to respond to changing customer requirements. 

Therefore, the waterfall model should only be used when the requirements are well 
understood and unlikely to change radically during system development. 

However, the waterfall model reflects the type of process model used in other 
engineering projects. Consequently, software processes based on this approach are still used 
for software development, particularly when the software project is part of a larger systems 


engineering project. 


Words 
automate vt. &vi. (动词 ) 自动 化 ,自动 操作 
cascade vt. &vi. (Mia) KE 
circumvented vt. & vi. (动词 ) 包围 ;陷害 ; 绕 行 
commitment n. (名 词 ) 承诺 ,保证 ;委托 ;承担 义务 ;献身 
configuring vt. & vi. (动词 ) 配置 ;使 成 形 
constraint n. (名 词 ) 约束 ;限制 ;约束 条 件 
consultation n. (名 词 ) 咨询 ;磋商 ;[ 临床] 会 诊 ;讨论 会 
e siu 
@ 5-8 
© 技巧 ;诡计 
© 省 略 
Q 死板 的 ; 硬 的 
© 承诺 ;保证 
Q ”完全 的 ;彻底 的 


à 1x 


definitive adj. (形容 词 ) 决定 性 的 ;最 后 的 ;限定 的 


derived vt. &vi. (动词 ) 得 到 ;推断 
fundamental adj. (形容 词 ) 基本 的 ,根本 的 
generic adj. (形容 词 ) 类 的 ;一 般 的 ; 属 的 ; 非 商 标的 
immense adj. (形容 词 ) 巨大 的 ,广大 的 ;无 边 无 际 的 
inflexible adj. (形容 词 ) 顽固 的 ;不 可 弯曲 的 
integrating vt. & vi. (动词 ) 整合 ;积分 ;集成 化 
intellectual adj. (形容 词 ) 智力 的 ;聪明 的 ;理智 的 
interleave n. (名 词 ) 交替 
iteration n. (名 词 ) ARKA; RE 
omission n. (名词) RA wim; 4S 3K 
overlap n. (4744) €. 
paradigm n. (名 词 ) 范例 ,模范 
partial adj. (形容 词 ) 局 部 的 ;偏爱 的 ;不 公平 的 
partition vt. &vi. (动词 ) AY Ft 
perspective adj. (形容 词 ) 透视 的 
phase n. (名 词 ) 阶段 ,时 期 
radically adv. (副词 ) 根本 上 ;彻底 地 ;以 激进 的 方式 
scope n. (名 词 ) ye H 
scratch n. (名 词 ) 草稿 
specification n. (名 词 ) 规格 ;说 明 书 ; 详 述 
validation n. (名 词 ) 确认 ;批准 ;生效 
verifying vt. &vi. (动词 ) 验证 ;核查 
Phrases 
architectural perspective 体系 结构 角度 
at least 至 少 
be delivered to 送 到 
because of 因为 ;由 于 
component-based software engineering 基于 组 件 的 软件 工程 
evolutionary development 演进 式 开发 
fleed...to 反馈 , Fe te 
in detail 详细 地 
in earlier stages of the life cycle 在 生命 周期 的 前 期 
take advantage of 利用 
takes over 接管 
the longest life-cycle phase 最 长 的 生命 周期 阶段 


s AO a 


the waterfall model 瀑布 模型 
think of 记 起 ,想起 ;考虑 ;想象 ;关心 


Exercises 


[Ex1] Answer the questions according to the text: 


(1) What is the software process? 

(2) What are the fundamental activities common to all software processes? 

(3) How to improve the software process? 

(4) Why do we need to freeze parts of the development after a small number of 
iterations? 


(5) Why must the system evolve to remain useful? 
[Ex2] Translate into Chinese: 


(1) A software process is a set of activities that leads to the production of a software 
product. 

(2) Because of the need for judgement and creativity, attempts to automate software 
processes have met with limited success. 

(3) One reason the effectiveness of CASE tools is limited is because of the immense 
diversity of software processes. 

(4) For business systems, with rapidly changing requirements, a flexible, agile process 
is likely to be more effective. 

(5) A software process model is an abstract representation of a software process. 

(6) The system development process focuses on integrating these components into a 
system rather than developing them from scratch. 

(7) During this stage, the software design is realized as a set of programs or program 
units. 

(8) The advantages of the waterfall model are that documentation is produced at each 


phase and that it fits with other engineering process models. 


[Ex3] Choose the best answer 


(1) means "Any HTML document a HTTP Server". 
A. Web server B. Web page 
C. Web browser D. Web site 

(2) The term “ program" means a program written in high-level language. 
A. compiler B. executable C. source D. object 


(3) Very long complex expressions in program are difficult to write correctly and 
es 


difficult to 
A. defend B. detect C. default D. debug 
(4) In C language, functions are important because they provide a way to 
code so that a large complex program can be written by combining many smaller parts. 
A. modify B. modularize C. block D. board 
(5) The standard in C language contain many useful functions for input and 
output, string handing, mathematical computations, and system programming tasks. 
A. databases B. files C. libraries D. subroutines 


批 注 

注 1 主语 : new software; iif: is developed; 状 语 : by extending and modifying existing systems and 
by configuring and integrating off-the-shelf software or system components。 这 人 句 话 的 含义 是 ; 逐渐 地 , 现 
在 越 来 越 多 的 软件 是 通过 在 旧 软 件 基础 上 修改 或 通过 配置 和 集成 现成 软件 或 系统 组 件 而 形成 的 。 

ip2 这 人 句 话 的 含义 是 : 但 是 ,更 广泛 的 上 月 动 化 的 可 以 蔡 代 工程 师 在 软件 过 程 中 的 有 创造 力 的 设 
计 至 少 在 今后 几 年 内 不 可 能 出 现 ;at least in the next few years 作为 插入 语 ;possibility of; ……- 的 可 能 。 

注 3 主语: Each process model; 谓 语 : represents ,provides。 这 人 句 话 的 含义 是 : 每 个 过 程 模 型 从 一 
个 特定 的 角度 表现 一 个 过 程 ,只 提供 过 程 的 某 一 方面 的 信息 。 

注 4 that 引导 一 个 主语 从 句 ; 先 行 词 是 process frameworks。 这 人 句 话 的 含义 是 : 你 可 以 将 这 些 模型 
看 作 过 程 处 理 框 架 , 可 以 扩展 并 修改 它们 创建 一 个 特殊 的 软件 工程 处 理 过 程 。 

TES 这 人 句 话 的 含义 是 : 这 个 模型 采用 一 些 基 本 的 过 程 活动 , 即 描述 、 开 发 有效 性 验证 和 进化 , 代 
表单 独 的 过 程 阶段 ( 如 需求 描述 软件 设计 、 实 现 和 测试 等 阶段 ) 表 现 这 些 活动 。 

ike 这 句 话 的 含义 是 : 集成 单个 的 程序 单元 或 程序 ,并 对 系统 整体 进行 测试 ,以 满足 需求 。 测 试 
之 后 ,将 软件 系统 交付 给 客户 使 用 。 

ik 7 Maintenance 为 主语 ;involves 为 谓语 ;correcting ,improving , enhancing 为 并 列 结构 。 

注 8 这 人 句 话 的 含义 是 : 在 实践 中 ,这 些 阶 段 相 互 重合 ,彼此 间 有 信息 交换 。 

ipo ”这 人 句 话 的 含义 是 : 因此 ,经 过 少量 的 反复 之 后 ,要 冻结 部 分 开发 过 程 ,如 描述 部 分 ,继续 进行 
后 面 的 开发 阶段 。 

TE10 ”这 人 句 话 的 含义 是 : 因此 ,系统 必须 进化 ,以 保持 实用 性 。 


Text B Introducing the UML 


The Unified Modeling Language9 ( UML) is a standard language for writing 
software blueprint9. The UML may be used to visualize, specify®, construct, and 
document the artifacts of a software- intensive system. 
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The UML is appropriate for modeling systems ranging from enterprise information 
systems to distributed Web-based applications and even to hard real time 
embedded systems9. It is a very expressive language, addressing all the views needed to 
develop and then deploy9 such systems. Even though it is expressive, the UML is not 
difficult to understand and to use. Learning to apply the UML effectively starts with forming 
a conceptual model of the language, which requires learning three major elements; the 
UMU's basic building blocks, the rules that dictate how these building blocks may be put 
together, and some common mechanisms that apply throughout the language. '* 

The UML is only a language, so it is just one part of a software development method. 
The UML is process independent, although optimally it should be used in a process that is 


use case driven, architecture-centric, iterative, and incremental. 
1. An overview of the UML 


The UML is a language for 
(1) Visualizing (2) Specifying (3) Constructing (4) Documenting 


2. The UML is a language 


A language provides a vocabulary and the rules for combining words in that vocabulary 
for the purpose of communication. A modeling language is a language whose vocabulary and 
rules focus on the conceptual and physical representation of a system. A modeling 
language such as the UML is thus a standard language for software blueprints. 

Modeling yields an understanding of a system. No one model is ever sufficient. 
Rather, you often need multiple models that are connected to one another to understand 
anything but the most trivial system. For software-intensive systems, this requires a 
language that addresses the different views of a system's architecture as it evolves throughout 


the software development life cycle. 
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The vocabulary and rules of a language such as the UML tell you how to create and read 
well-formed models, but they don't tell you what models you should create and when you 
should create them. That's the role of the software development process. A well-defined 
process will guide you in deciding what artifacts to produce, what activities and what workers 
to use to create them and manage them, and how to use those artifacts to measure and control 


the project as a whole. '? 
3. The UML is a language for visualizing 


For many programmers, the distance between thinking of an implementation9 and 
then pounding it out in code is close to zero. You think it, you code it. In fact, some things 
are best cast directly in code. Text is a wonderfully minimal® and direct way to write 
expressions and algorithms9. 

In such cases, the programmer is still doing some modeling, albeit9 entirely mentally. 
He or she may even sketch out a few ideas on a white board9 or on a napkin9. 
However, there are several problems with this. First, communicating those conceptual 
models to others is error-prone9 unless everyone involved speaks the same language. ™ 
Typically, projects and organizations develop their own language, and it is difficult to 
understand what's going on if you are an outsider or new to the group. Second, there are 
some things about a software system you can't understand unless you build models that 
transcend® the textual programming language. For example, the meaning of a class 
hierarchy9 can be inferred, but not directly grasped, by staring at the code for all the 
classes in the hierarchy. Similarly, the physical distribution and possible migration9 of the 
objects in a Web-based system can be inferred, but not directly grasped, by studying the 
system's code. '^ Third, if the developer who cut the code never wrote down the models that 
are in his or her head, that information would be lost forever or, at best, only partially re- 
creatable from the implementation once that developer moved on. 

Writing models in the UML addresses the third issue; an explicit model facilitates 


communication. 
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Some things are best modeled textually; others are best modeled graphically9. 
Indeed, in all interesting systems, there are structures that transcend what can be represented 
in a programming language. The UML is such a graphical language. This addresses the 
second problem described earlier. 

The UML is more than just a bunch of graphical symbols. 55 Rather, behind each 
symbol in the UML notation is a well-defined9 semantics®. In this manner, one 
developer can write a model in the UML, and another developer, or even another tool, can 


interpret that model unambiguously®. This addresses the first issue described earlier. 
4. The UML is a language for specifying 


In this context, specifying means building models that are precise, unambiguous, and 
complete. In particular, the UML addresses the specification of all the important analysis, 
design, and implementation decisions that must be made in developing and deploying a 


software-intensive system. 
5. The UML is a language for constructing 


The UML is not a visual programming language, but its models can be directly 
connected to a variety of programming languages. This means that it is possible to map from 
a model in the UML to a programming language such as Java, C++, or Visual Basic, or 
even to tables in a relational database or the persistent store of an object-oriented 
database. *° Things that are best expressed graphically are done so graphically in the UML, 
whereas things that are best expressed textually are done so in the programming language. 


This mapping® permits forward engineering the generation of code from a UML model 


into a programming language. The reverse is also possible: You can reconstruct a model 


from an implementation back into the UML. * Reverse engineering is not magic. Unless you 
encode that information in the implementation, information is lost when moving forward from 


models to code. Reverse engineering thus requires tool support with human intervention9. 


Combining these two paths of forward code generate and reverse engineering yields round-trip 


engineering mean the ability to work in either a graphical or a textual view, while tools keep 


the two views consistent. #8 
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In addition to this direct mapping, the UML is sufficiently expressive and unambiguous 
to permit the direct execution of models, the simulation9 of systems, and the 


instrumentation9 of running systems. 
6. The UML is a language for documenting 


A healthy software organization produces all sorts of artifacts in addition to raw 
executable code. These artifacts include (but are not limited to) 
Requirements 
Architecture 
Design 
Source code 
Project plans 
Tests 
Prototypes® 
Releases 
Depending on the development culture, some of these artifacts are treated more or less 
formally than others. Such artifacts are not only the deliverables of a project, they are also 
critical® in controlling, measuring, and communicating about a system during its 
development and after its deployment. 
The UML addresses the documentation of a system’s architecture and all of its details. 
The UML also provides a language for expressing requirements and for tests. Finally, the 


UML provides a language for modeling the activities of project planning and release 


management. 
Words 

albeit n. (名 词 ) 尽管 
artifact n. (名 词 ) 人 工 制品 
blueprint n. (名 词 ) 蓝图 
conceptual adj. (形容 词 ) 概念 的 
critical adj. (形容 词 ) 关键 的 
database n. (名 词 ) 数据 库 
deploy vt. &vi. (动词 ) 使 展开 

Q 模拟 
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© 原型 

e 关键 的 


dictate 
graphically 
hierarchy 
implementation 
incremental 
instrumentation 
intensive 
intervention 
iterative 
mapping 
mechanism 
migration 
minimal 
multiple 
optimally 
persistent 
precise 
prototype 
representation 
semantics 
simulation 
specify 
transcend 
trivial 
unambigously 


yield 


a white board 


vt. &vi. (动词 ) 
adv. (副词 ) 


n. (名 词 ) 
n. (名 词 ) 
n. (名 词 ) 
n. (名 词 ) 


adj. (形容 词 ) 
vt. &vi. (动词 ) 
adj. (形容 词 ) 
n. (名词 ) 

n. (名 词 ) 

vt. &vi. ( 5177) 
adj. (形容 词 ) 


n. (名 词 ) 
adv. (副词 ) 
n. (名 词 ) 
adj. ( 形容词) 
n. (名 词 ) 

n. (名 词 ) 

n. (名 词 ) 

n. (名 词 ) 

n. (名 词 ) 


vt. &vi. (动词 ) 
adj.( 形容词) 
复合 词 

vt. & vi. (74) 


Phrases 


enterprise information systems 


error-prone 


real time embedded systems 


software-intensive system 


Unified Modeling Language 


Web-based applications 


支配 


生动 地 ;用 图 表 表 示 ; 用 图 解法 


层次 

实施 ;履行 
增 量 
仪器 仪表 
集 中 的 H 加 强 的 
干预 
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映射 

机 制 

迁移 

最 小 的 
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详 述 

超越 

琐碎 ;细小 
毫 不 含糊 地 
产生 
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实时 岁入 式 系统 
软件 -密集 的 系统 
统一 建 模 语 言 

网 页 化 应 用 程序 
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well-defined 定义 明确 的 ;界限 清楚 的 


批 注 

注 1 Learning to apply the UML effectively 为 主语 ;starts 为 谓 霹 ;which 引导 一 个 非 限制 性 定语 从 
^h] that dictate how these building blocks may be put together 的 先行 词 为 the rules;that apply throughout the 
language 的 先行 词 为 mechanisms。 这 人 句 话 的 含义 是 : 要 学 习 使 用 UML ,一 个 有 效 的 出 发 点 是 形成 该 语 
言 的 概念 模型 ,这 要 求学 习 3 NER: UML 的 基本 构造 块 . 文 配 这 些 构造 块 如 何 放置 在 一 起 的 规则 以 及 
运用 于 整个 语言 的 一 些 公 共 机 制 。 

注 2 A well-defined process 为 主语 ;will guide 为 谓语 ;what,what and how 的 先行 词 为 deciding。 

注 3 这 人 句 话 的 含义 是 : 他 们 甚至 可 以 在 白板 或 餐巾 纸 上 和 草拟 出 一 些 想法 。 然 而 ,这 样 做 存在 几 个 
问题 。 第 一 ,别人 对 这 些 概念 模型 容易 产生 错误 的 理解 ,因为 并 不 是 每 个 人 都 使 用 相同 的 语言 。 

注 4 这 句 话 的 含义 是 : 例如 ,对 于 一 个 类 的 所 有 代码 , 虽 可 推 新 出 它 的 含义 ,但 不 能 直接 领会 它 。 
类 似 地 ,在 基于 Web 的 系统 中 人 研究 系统 的 代码 虽 可 推断 出 对 象 的 物理 分 布 和 可 能 的 迁移 ,但 也 不 能 直 
接 领会 它 。 

注 5 more than; 只 不 过 ,充其量 。 这 人 句 话 的 含义 是 : UML 只 不 过 是 图 形 符号 的 一 个 分 文 。 

注 6 that 引导 一 个 宾语 从 人 句 , 先行 词 是 means, or even to tables in a relational database or the 
persistent store of an object-oriented database. 这 人 句 前 面 省 略 f it is possible。 这 人 句 话 的 含义 是 ; 这 意味 看 
一 种 可 能 性 , 即 可 把 用 UML 描述 的 模型 映射 成 编程 语言 ,如 Java C++ 和 Visual Basic 等 ,甚至 映射 成 天 
系数 据 库 的 表 或 面 问 对 象 数据 库 的 永久 储存 。 

注 7 这 人 句 话 的 含义 是 : 可 以 进行 逆 癌 工程 一 一 由 编程 语言 代码 重新 构造 UML 模型 。 

注 8 iB Combining these two paths of forward code generate and reverse engineering yields round- 
trip engineering; Wi Hy: mean;or a textual view 省 略 f work ing KAN SCE: 把 正 癌 代码 生成 和 逆 回 
工程 这 两 种 方式 结合 起 来 就 可 以 产生 双 癌 工程 ,这 意味 者 既 能 在 图 形 视 图 下 工作 ,又 能 在 文字 视图 下 工 
作 , 只 要 用 工具 保持 二 者 的 一 致 性 即 可 。 


Associated Reading 


Guidelines of UML Activity Diagrams 


In many ways UML Activity diagrams are the object-oriented equivalent of flow charts 
and data-flow diagrams ( DFDs). They are used to explore the logic of; 

* A complex operation 

* A complex business rule 

* A single use case 

e Several use cases 

* A business process 


e Software processes 


i s 


Guidelines: 


1. General guidelines 

Place " The Start Point" In The Top-Left Corner. A start point is modeled with a filled 
in circle, using the same notation that UML State Chart diagrams use. Every UML Activity 
Diagram should have a starting point, and placing it in the top-left corner reflects the way that 
people in Western cultures begin reading. Figure 4-2 which models the business process of 


enrolling in a university, takes this approach. 


[otherwise] 
| Enrolling in the 
Fill Out | [help available] "c ori MEDI for the first 
un ain Hep to F1 ime 
Enrollment Forms een | Out Forms panne 
problems 


[correct] 


Attend University 
Overview 
Presentation 


Enroll In Make Initial Tuition 
Seminar(s) Payment 


Figure 4-2 Activity diagram 


Enroll in 
University 


Always Include an Ending Point. An ending point is modeled with a filled in circle with 
a border around it, using the same notation that UML State Chart diagrams use. Figure 4-2 is 
interesting because it does not include an end point because it describes a continuous process- 
sometimes the guidelines don’t apply. 

Flowcharting Operations Implies the Need to Simplify. A good rule of thumb is that if 
an operation is so complex you need to develop a UML Activity diagram to understand it that 
you should consider refectory it. 

2. Decision points 

A decision point is modeled as a diamond on a UML Activity diagram. Decision Points 
Should Reflect the Previous Activity. In Figure 4-2 you see that there is no label on the 
decision point, unlike traditional flowcharts which would include text describing the actual 
decision being made, you need to imply that the decision concerns whether the person was 
enrolled in the university based on the activity that the decision point follows. The guards 
depicted using the format | description | on the transitions leaving the decision point also 
help to describe the decision point. 

Avoid Superfluous Decision Points. The Fill Out Enrollment Forms activity in 
Figure 4-2 includes an implied decision point, a check to see that the forms are filled out 


properly , which simplified the diagram by avoiding an additional diamond. 
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3. Swim lane guidelines 
A swim lane is a way to group activities performed by the same actor on an activity 


diagram or to group activities in a single thread. Figure 4-3 includes three swim lanes, one 


for each actor. 
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Figure 4-3 A UML activity diagram for the enterprise architectural modeling 


M PA 


Unit5 Database 


Text A MySQL Introduction 


The MySQL database system uses a client/server9 architecture9 that centers on the 
server. The server is the program that actually manipulates® databases. Client programs 
don't do that directly. Instead, they communicate your intent to the server by means of 
statements written in Structured Query Language ( SQL ). Client programs are 
installed locally on the machine from which you want to access MySQL, but the server can 
be installed anywhere, as long as clients can connect to it. *' MySQL is an inherently® 
networked database system, so clients can communicate with a server that is running locally 
on your machine or one that is running somewhere else, perhaps on a machine on the other 
side of the planet. Clients can be written for many different purposes, but each interacts 
with the server by connecting to it, sending SQL statements to it to have database operations 
performed, and receiving the statement results from it. 

One such client is the MySQL program that is included in MySQL distributions®. 
When used interactively, MySQL prompts you for a statement, sends it to the MySQL server 
for execution, and then displays the results. ? This capability makes MySQL useful in its 
own right, but it's also a valuable tool to help you with your MySQL programming activities. 
It’s often convenient tof be able to quickly review the structure of a table that you're 
accessing from within a script, to try a statement before using it in a program to make sure 
that it produces the right kind of output, and so forth. MySQL is just right for these jobs. 


MySQL also can be used non-interactively; for example, to read statements from a file or 
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from other programs. This enables you to use MySQL from within scripts or cron jobs or in 
conjunction® with other applications. 

This chapter describes MySQL’s capabilities so that you can use it more effectively; 

e Starting and stopping MySQL 

è Specifying connection parameters and using option files 

e Setting your PATH variable so that your command interpreter can find MySQL 

( and other MySQL programs ) 

e Issuing SQL statements interactively® and using batch files 

e Canceling and editing statements 

e Controlling9 MySQL output format 

To use the examples shown, you'll need a MySQL user account and a database to work 
with. The first two sections of the chapter describe how to use MySQL to set these up. For 
demonstration® purposes, the examples assume9 that you'll use MySQL as follows: 

e The MySQL server is running on the local host 

e Your MySQL username and password are cbuser and cbpass 

e Your database is named cookbook 

For your own experimentation®, you can violate® any of these assumptions. Your 
server need not be running locally, and you need not use the username, password, or 
database name that are used in this charpter. E Naturally, if you use different default values 
on your system, you'll need to change the examples accordingly. 

Even if you do not use cookbook as the name of your database, I recommend that you 
create a database to be dedicated specifically to trying the examples shown here, rather than 
trying them with a database that you're using currently for other purposes. 型 Otherwise, the 
names of your existing tables may conflict with those used in the examples, and you'll have to 
make modifications to the examples that are unnecessary when you use a separate database. 

If you have another favorite client program to use for issuing queries, some of the 
concepts covered in this chapter may not apply. For example, you might prefer the graphical 


MySQL Query Browser program, which provides a point-and-click interface to® 
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MySQL databases. In this case, some of the principles will be different, such as the way that 


you terminate9 SQL statements. In MySQL, you terminate statements with semicolon ( ;) 


characters, whereas in MySQL Query Browser? there is an Execute button for terminating 
statements. ? Another popular interface is phpMyAdmin, which enables you to access 


MySQL through your web browser. 


Words 

architecture n. (名 词 ) 风格 ,模式 
assume vt. & vi. (动词 ) 假定 
browser n. (名 词 ) 浏览 器 
conjunction n. (名 词 ) 同时 发 生 
controlling vt. &vi. (动词 ) 控制 ;管理 
dedicated adj. (形容 词 ) 专用 的 
demonstration n. (名 词 ) 示范 ;演示 
display vt. & vi. (动词 ) 展示 ;显示 
distribution n. (474) 分 配 ;分 布 
experimentation n. (名 词 ) 实验 ;试验 
inherently adv. (副词 ) 与 生 俱 来 地 
intent n. (名 词 ) 意图 ;目的 
interact vt. & vi. (动词 ) 互相 影响 
interactively adv. (副词 ) 交互 式 地 
interpreter n. (名 词 ) 解释 器 
manipulate vt. &vi. (动词 ) 操作 ;操纵 
parameter n. (名 词 ) 参数 ;系数 
Script n. (名 词 ) 手迹 ;脚本 
statement n. (名 词 ) 语句 ,命令 
terminate vt. & vi. (动词 ) 结束 ,终止 
violate vt. (动词 ) 违反 

Phrases 
client/ server Z P 3g/ B Be 
convenient to 便捷 的 ,方便 的 
on the other side z —W,z — 
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point-and-click interface to 单 击 鼠 标 接口 


so forth 等 等 
Structured Query Language 结构 化 查询 语言 
Exercises 


[Ex1] Fill in the blanks according to the text: 


(1) The MySQL database uses a client-server architecture that centers around 
the server. 

(2) The server is the program that actually databases. 

(3) This makes MySQL useful in its own right, but it's also a valuable tool to 
help you with your MySQL programming activities. 

(4) Otherwise, the names of your existing tables may with those used in the 
examples. 


(5) In this case, some of the principles will be different, such as the way that 
you SQL statements. 


[Ex2] Translate into Chinese: 


(1) The MySQL database system uses a client/server architecture that centers around 
the server. 

(2) The server is the program that actually manipulates databases. Client programs 
don't do that directly. 

(3) MySQL is an inherently networked database system, so clients can communicate 
with a server that is running locally on your machine or one that is running somewhere else. 

(4) One such client is the MySQL program that is included in MySQL distributions. 

(5) MySQL also can be used noninteractively; for example, to read statements from a 
file or from other programs. 

(6) This enables you to use MySQL from within scripts or cron jobs or in conjunction 
with other applications. 

(7) Another popular interface is phpMyAdmin, which enables you to access MySQL 
through your web browser. 

(8) In this case, some of the principles will be different, such as the way that you 
terminate SQL statements. 


[Ex3] Choose the best answer: 


(1) What's the system used in MySQL? 
A. The MySQL database system uses a client/server architecture. 
B. The MySQL database system uses a point-to-point architecture. 
C. The MySQL database system uses both client/server and point-to-point 
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architecture. 

D. Not mentioned. 
(2) Which part does actually manipulate the MySQL database? 

A. The server. B. The client. 

C. The sever and client. D. Not mentioned. 
(3) Where could a client program was installed? 

A. Locally on your machine. B. Other place where have net. 

C. The mechine near the server. D. Not mentioned. 
(4) Which is begond MySQL’s capabilities? 

A. Starting and stopping MySQL. 

B. Canceling and editing statements. 

C. Specifying connection parameters and using option files. 

D. Manipulating the MySQL database. 
(5) Where does the MySQL execute statement? 

A. In MySQL. B. In client. 


C. In server. D. Both in client and server. 


批 o 

注 1 -Ei&; Client programs; ifii#; are;but the server can be installed anywhere, as long as clients can 
connect to it 与 前 面 是 并 列 关 系 ;as long as 引导 一 个 条 件 状 语 从 句 。 

注 2 这 句 话 的 含义 是 : 当 你 交互 时 ,MySQL 通过 一 个 语句 提示 把 语句 发 送 到 MySQL 服务 器 执 
行 ,然后 显示 结果 。 

注 3 这 人 句 话 是 一 个 并 列 句 ;Your server, and you 为 句子 的 主语 ;that are used in this charpter 引导 一 
个 定语 从 名 ,先行 词 是 username, password, or database name。 这 人 句 话 的 含义 是 : PRAY RS ait AY BE AS FE 
本 地 运行 ,你 不 需要 使 用 用 户 名 密码 数据 库 的 名 字 。 

注 4 这 人 句 话 的 含义 是 : 我 建议 你 根据 这 里 提供 的 例子 创建 一 个 数据 库 ,或 者 为 不 同 的 目的 试用 
它们 。 

注 5 whereas 引导 一 个 非 限 制 性 定语 从 名。 这 人 句 话 的 含义 是 : E MySQL 里 ,你 可 以 使 用 分 号 作为 
结束 语句 ,而 MySQL Query Browser 中 有 一 个 专门 的 执行 符号 用 来 结束 语句 。 


Text B Performing Transactions 


The MySQL server can handle9 multiple clients at the same time because it is 


multithreaded9. To deal with contention among clients, the server performs any 


@ 处理; 操作 
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necessary locking so that two clients cannot modify the same data at once. ** However, as 
the server executes SQL statements, it's very possible that successive® statements received 
from a given client will be interleaved® with statements from other clients. If a client 
issues9 multiple statements that are dependent on9 each other, the fact that other clients 
may be updating tables in between those statements can cause difficulties. Statement failures 
can be problematic, too, if a multiple-statement operation does not run to completion. 
Suppose that you have a flight table containing information about airline flight schedules and 


you want to update the row for Flight 578 by choosing a pilot from among those available. - 


You might do so using three statements as follows: 


SIFT @ p val := pilot id FRM pilot WHERE available = 'yes' LIMIT 1; 
UPDATE pilot SET available = 'no' WHERE pilot id— 8 p val; 
UPDATE: flight SET pilot id=@ p val WHERE flight id- 578; 


The first statement chooses one of the available pilots, the second marks the pilot as 
unavailable , and the third assigns the pilot to the flight. 35 That's straightforward enough in 
practice, but in principle there are a couple of® significant difficulties with the process; 

If two clients want to schedule pilots, it's possible that both of them would run the 
initial SELECT query and retrieve the same pilot ID number before either of them has a 
chance to set the pilot's status to unavailable. If that happens, the same pilot would be 
scheduled for two flights at once. 

All three statements must execute successfully as a unit. For example, if the SELECT 
and the first UPDATE run successfully, but the second UPDATE fails, the pilot's status is set 
to unavailable without the pilot being assigned a flight. The database will be left in an 
inconsistent state. 

To prevent concurrency and integrity problems in these types of situations, 
transactions are helpful. A transaction groups a set of® statements and guarantees the 
following properties. 
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* No other client can update the data used in the transaction while the transaction is in 
progress; For example, other clients cannot modify the pilot or flight records while 
you're booking a pilot for a flight. By preventing other clients from interfering with 
the operations you're performing, transactions solve concurrency problems arising 
from the multiple-client nature of the MySQL server. Transactions serialize® access 
to a shared resource across multiple-statement operations. 

e Statements in a transaction are grouped and are committed9 ( take effect) as a unit, 
but only if they all succeed. ** If an error occurs®, any actions that occurred 
prior? to the error are rolled back, leaving the relevant9 tables unaffected as 
though none of the statements had been issued at all. This keeps the database from 
becoming inconsistent. For example, if an update to the flights table fails, 
rollback causes the change to the pilots table to be undone, leaving the pilot still 
available. Rollback frees you from having to figure out9 how to undo a partially 


completed operation yourself. 


Words 

assign vt. &vi. (动词 ) 分 配 ; 指 派 
committed adj. (形容 词 ) 提交 ;起 作用 
guarantee vt. &vi. (动词 ) 保证 ;担保 
handle vt. &vi. (动词 ) 处 理 ;操作 
inconsistent adj. (形容 词 ) 不 一 致 的 
initial adj. (和 形容词) 最 初 的 ; 字 首 的 
interleave adj. (WA); v. (动词 ) 隔行 扫描 的 交错 ;交叉 存 取 
issue vt. & vi. (动词 ) 发 布 
multiple adj. (形容 词 ) 并 联 , 多 个 的 
multithread adj. (形容 词 ) 多 线程 的 
occur vt. & vi. (动词 ) 发 生 ; 出 现 
prior adj. (形容 词 ) 之 前 的 
problematic adj. (形容 词 ) 有 疑问 的 
property n. (名 词 ) 性 能 ;属性 

品行 序列 地 

提交 ;起 作用 

发 生 ; 出 现 

之 前 的 

有 关 的 

不 一 致 的 

找 出 ,计算 出 
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relevant adj. (形容 词 ) AK BY 


serialize vt. & vi. (动词 ) 串 行 序列 地 

successive adj. (形容 词 ) 连续 的 

transaction n. (名 词 ) 处 理 ,事务 
Phrases 

a couple of 许多 

a set of 一 组 

deal with Ab XE 

dependent on 依赖 

figure out 找 出 ,计算 出 

in principle 大 体 上 ,原则 上 

so that 以 便 ; 以 使 


批 注 

注 1 这 人 句 话 的 含义 是 : 为 了 处 理 客户 端 间 内 容 方 面 的 事务 ,服务 右 有 一 个 锁 的 操作 ,这 样 两 个 客 
户 端 程序 不 可 能 在 同一 时 刻 修改 相同 数据 。 

注 2 这 人 句 话 的 含义 是 : 假设 你 有 一 张 航 班 信息 表 , 里 面包 含 航线 航班 计划 信息 ,需要 从 可 供 选 择 
的 飞行 员 中 选择 一 位 飞行 员 ,更 新 578 航班 记录 。 

注 3 ”这 名 话 的 含义 是 : 第 一 条 语句 用 于 选择 一 个 飞行 员 , 第 二 条 语句 用 于 设置 该 飞行 员 为 无 效 ， 
第 三 条 语句 将 该 飞行 员 分 配给 这 次 航班 。 

注 4 这 人 句 话 的 含义 是 : 在 事务 里 的 语句 是 成 组 的 ,只 有 当 它 们 执行 成 功 时 ,是 作为 整个 单元 委 
效 的 。 


Associated Reading 


Pattern Matching in SQL Server Queries 


You may often need to create a SQL Server query that performs inexact pattern matching 
through the use of wildcard characters. The use of wildcards allows you to find data that fits 
a certain pattern, rather than specifying it exactly. For example, you can use the wildcard 
*C96' to match any string beginning with a capital C. 

To use a wildcard expression in a SQL query, you'll need to use the LIKE clause to 
specify it. For example, you could search for any employee in your database with a last name 
beginning with the letter C using the following SQL statement: 


SFIFCT * FROM employees WHERE last name LIKE ' C$ . 


There are several different wildcard expressions supported by Transact SQL: 


c as 


e The % wildcard matches zero or more characters of any type. If you're familiar 
with® DOS pattern matching, it's the equivalent of the * wildcard in that syntax. 

è The _ wildcard matches exactly one character of any type. It's the equivalent of ® 
the? wildcard in DOS pattern matching. 

* You can specify a list of characters by enclosing them in square brackets. For 
example, the wildcard | aeiou | will match any vowel. 

* You can specify a range of® characters by enclosing the range in square brackets. 
For example, the wildcard | a-m | will match any letter in the first half of the 
alphabet. 

* You can negate a range of characters by including the carat character immediately 
inside of the opening square bracket. For example, | ^aeiou | matches any non-vowel 
character while | ^a-m | matches any character not in the first half of the alphabet. 

You may also combine these wildcards in complex patterns to9 perform more 

advanced queries. For example, suppose you needed to construct a list of all of your 
employees who have names that begin with a letter from the first half of the alphabet but do 
NOT end with a vowel. You could use the following query : 


SELECT * FRM employees WHERE last name LIKE '[a-m]$ [^aeiou]' 

Similarly, you could construct a list of all employees with last names consisting of 
exactly four characters by using the query: 

SELECT * FRM employees WHERE last name LIKE ' 


As you can tell, the use of SQL Server's pattern matching capabilities offers database 


users the ability to go beyond simple text queries and perform advanced searching operations. 
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Unit6 Embedded System 


Text A What is an Embedded System? 


One of the more surprising developments of the last few decades has been the 
ascendance of computers to a position of prevalence9 in human affairs9. Today 
there are more computers in our homes and offices than there are people who live and work in 
them. *' Yet many of these computers are not recognized as such by their users. In this unit, 
lll explain what embedded systems are and where they are found. I will also introduce the 
subject of embedded programming, explain why I have selected C and C++ as the languages 


for this book, and describe the hardware used in the examples. 
1. About embedded system 


An embedded system is a combination of computer hardware and software, and perhaps 
additional mechanical or other parts, designed to perform a specific function. A good 
example is the microwave oven9. Almost every household has one, and tens of millions of 
them are used every day, but very few people realize that a processor and software are 
involved in the preparation? of their lunch or dinner. 

This is in direct contrast to the personal computer in the family room. It too is 
comprised of® computer hardware and software and mechanical components ( disk 
drives, for example). However, a personal computer is not designed to perform a specific 
function. Rather, it is able to do many different things. Many people use the term general- 
purpose computer® to make this distinction clear. As shipped, a general-purpose 
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computer is a blank slate; the manufacturer. does not know what the customer will do 
with it. One customer may use it for a network file server, another may use it exclusively 
for playing games, and a third may use it to write the next great American novel. 

Frequently, an embedded system is a component within some larger system. For 
example, modern cars and trucks contain many embedded systems. One embedded system 
controls the anti-lock brakes, another monitors and controls the vehicle’s® 
emissions, and a third displays information on the dashboard®. ® In some cases, these 
embedded systems are connected by some sort of a communications network, but that is 
certainly not a requirement. 

At the possible risk of confusing you, it is important to point out that a general-purpose 
computer is itself made up of numerous® embedded systems. For example, my 
computer consists of a keyboard, mouse, video card, modem, hard drive, floppy drive, and 
sound card-each of which is an embedded system. Each of these devices contains a processor 
and software and is designed to perform a specific function. For example, the modem is 
designed to send and receive digital data over an analog telephone line. That's it. And all 
of the other devices can be summarized® in a single sentence as well. 

If an embedded system is designed well, the existence of the processor and software 
could be completely unnoticed® by a user of the device. Such is the case for a microwave 
oven, VCR, or alarm clock. In some cases, it would even be possible to build an 
equivalent device that does not contain the processor and software. This could be done by 
replacing the combination with a custom integrated circuit9 that performs the same 
functions in hardware. However, a lot of flexibility is lost when a design is hard-coded in 
this way. It is much easier, and cheaper, to change a few lines of software than to redesign a 


piece of9 custom hardware. 
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2. History and future 


The first such systems could not possibly have appeared before 1971. That was the year 
Intel introduced the world’s first microprocessor9. This chip®, the 4004, was designed 
for use in a line of business calculators produced by the Japanese company Busicom. In 
1969, Busicom asked Intel to design a set of custom integrated circuits-one for each of their 
new calculator models. The 4004 was Intel's response. Rather than design custom hardware 
for each calculator, Intel proposed a general-purpose circuit that could be used throughout the 
entire line of calculators. This general-purpose processor was designed to read and execute a 
set of instructions-software-stored in an external9 memory chip. Intel's idea was that the 
software would give each calculator its unique set of features. 

The microprocessor was an overnight success, and its use increased steadily over the 
next decade. Early embedded applications included unmanned space probes, 
computerized traffic lights, and aircraft flight control systems. In the 1980s, embedded 
systems quietly rode the waves of the microcomputer age and brought microprocessors into 
every part of our personal and professional lives. Many of the electronic devices in our 
kitchens (bread machines®, food processors, and microwave ovens), living rooms 
(televisions, stereos, and remote controls) , and workplaces (fax machines, pagers, laser 
printers, cash registers, and credit card readers) are embedded systems. 

It seems inevitable that the number of embedded systems will continue to increase 
rapidly. Already there are promising new embedded devices that have enormous market 
potential9. light switches and thermostats that can be controlled by a central computer, 
intelligent air-bag® systems that don't inflate when children or small adults are present, 


palm-sized electronic organizers9 and personal digital assistants ( PDAs9) , digital 


cameras, and dashboard navigation systems. es Clearly, individuals who possess the skills 
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and desire to design the next generation of embedded systems will be in demand for quite 


some time. 
3. Real-Time systems 


One subclass of embedded systems is worthy of@ an introduction at this point. As 
commonly defined, a real-time system is a computer system that has timing constraints9. 
In other words, a real-time system is partly specified in terms of its ability to make certain 
calculations or decisions in a timely manner. These important calculations are said to have 
deadlines for completion. And, for all practical purposes, a missed deadline is just as bad 
as® a wrong answer. 

The issue of what happens if a deadline is missed is a crucial one. For example, if the 
real-time system is part of an airplane's flight control system, it is possible for the lives of the 
passengers and crew to be endangered by a single missed deadline. However, if instead the 
system is involved in@ satellite9 communication, the damage could be limited to a single 
corrupt data packet. 4 The more severe the consequences, the more likely it will be said 
that the deadline is "hard" and, thus, the system a hard real-time system. Real-time systems 
at the other end of this continuum? are said to have “soft” deadlines. 

The designer of a real-time system must be more diligent in his work. He must guarantee 
reliable operation of the software and hardware under all possible conditions. ¥ And, to the 
degree that human lives depend upon the system's proper execution, this guarantee must be 


backed by engineering calculations and descriptive paperwork. 


Words 


analog n. (名 词 ); adj. (和 形容词) HJEM; 自 ] 模 拟 的 ;有 长 
短 针 的 ,类 比 

anti-lock brakes 复合 名 词 防 章 车 锁 死 

ascendance n. (名 词 ) 优势 ;支配 力量 


参与 
微型 ,人 造 卫 星 
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component 
computerize 
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corrupt 
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introduction 
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preparation 
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n. (名 词 ) 

n. (名 词 ) 

adj.( 形容词 ) 
n. (名 词 ) 

vt. &vi. (动词 ) 
adj. (形容 词 ) 
n. (474) 

adj. (形容 词 ) 
n. (名词 ) 

n. (名词 ) 

n. (名词 ) 

adv. (动词 ) 
adj. ( 形容词 ) 
adj. (形容 词 ) 

. (名 词 ) 
(名 词 ) 

. (474) 
(名 词 ) 

. (名 词 ) 

. (474) 

adj. (形容 词 ) 
n. (名 词 ) 

n. (名 词 ) 

n. (名 词 ) 

n. (名 词 ) 

vt. & vi. (Mia) 
n. (名 词 ) 

vt. &vi. (动词 ) 
n. (名 词 ) 

vt. &vi. (动词 ) 
n. (名 词 ) 

adj.( 形容词 ) 
adj.( 形容词) 
n. (名 词 ) 
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Phrases 


一 片 ,一世 
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-让 
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部 件 , 组 成 部 分 

用 计算 机 操作 的 
约束 ,限制 

对 比 , 反 差 
破坏 的 ,腐败 的 
DUK S 
描述 的 ,叙述 的 

差别 ,分 别 ; 优 秀 ,荣誉 
发 出 ,发 光 , 放 射 物 
等 价 物 

仅 , 占 

外 部 的 

不 可 避免 的 ,必然 发 生 的 
介绍 ,引进 
制造 商 ,制造 厂 
微 处 理 器 

微波 ,微波炉 
检测 器 ,显示 器 

导航 ,航行 ,航海 
众多 的 ,许多 的 
个 人 数字 助理 

电位 ,电势 

准备 ,预备 ,配置 
传播 ,流行 ,普及 

探索 ,调查 
微型 ,人 造 卫 星 
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概括 ,总结 

恒温 器 

无 人 操纵 的 ,未 经 过 训练 的 
被 忽略 的 ,不 被 重视 的 
交通 工具 ,车 辆 


as bad as 与 .…… 一 样 糟糕 


at the other end of AAW 

be involved in 参与 

be worthy of 值得 , 配 得 上 

bread machines 面包 机 

comprised of Bee 组 成 

continuum 连续 时 间 

electronic organizers 电子 组 织 者 

food processors 食品 处 理 器 

general-purpose computer 通用 计算 机 

in human affairs 人 类 事务 

in terms of 依据 ;就 ……: 而 言 

integrated circuit 集成 电路 

involved in 涉及 ;包含 ; 率 涉 进 …… 

made up of Hee 组 成 

microwave ovens 微波 ;微波 炉 

personal digital assistants 个 人 数字 助理 
Exercises 


[Ex1] Fill in the blanks according to the text: 


Early embedded applications included space i traffic 
lights, and aircraft control systems. In the 1980s, embedded systems quietly rode 
the waves of the microcomputer age and brought microprocessors into every part of our 


personal and professional 
[Ex2] Translate into Chinese: 


(1) An embedded system is a combination of computer hardware and software, and 
perhaps additional mechanical or other parts, designed to perform a specific function. 

(2) In the 1980s, embedded systems quietly rode the waves of the microcomputer age 
and brought microprocessors into every part of our personal and professional lives. 

(3) For example, if the real-time system is part of an airplane’s flight control system, it 
is possible for the lives of the passengers and crew to be endangered by a single missed 
deadline. 

(4) The hardware reads digital data from one set of electrical connections and writes an 
analog version of the data to an attached telephone line. 

(5) If you are lucky, the documentation provided with your hardware will contain a 

i a 


superset of the block diagram you need. 

(6) If you think about it from this perspective, one thing you quickly realize is that the 
processor has a lot of compatriots. 

(7) Instead of simply storing the data that is provided to it, a peripheral might instead 
interpret it as a command or as data to be processed in some way. 

(8) Already there are promising new embedded devices that have enormous market 
potential; light switches and thermostats that can be controlled by a central computer, 
intelligent air-bag systems that don't inflate when children or small adults are present, palm- 
sized electronic organizers and personal digital assistants (PDAs), digital cameras, and 


dashboard navigation systems. 
[Ex3] Choose the best answer: 


(1) Today there are computers in our homes and offices than there are people 
who live and work in them. 
A. less B. more C. little D. lots of 
(2) For example, the modem is designed to send and receive digital data an 
analog telephone line. 
A. over B. in C. through D. on 


(3) Rather than design custom hardware for each calculator, Intel proposed a general- 


purpose that could be used throughout the entire line of calculators. 
A. computer B. board C. machine D. circuit 
(4) Before picking the board, you should be able to answer two basic 


questions about it. 
A. out B. up C. on D. to 
(5) Data to be printed is from either serial port, held in RAM until the printer 
is ready for more data, and delivered to the printer via the parallel port. 


A. trended B. transported C. accepted D. received 


批 注 

注 1 more… than; 比 …… 更 。 这 人 句 话 的 含义 是 : 今天 在 我 们 的 家 里 和 办 公 室 里 ,计算 机 的 数量 要 
比 使 用 它们 生活 和 工作 的 人 还 多 。 

注 2 这 人 名 话 的 含义 是 ; 一 个 衣 和 人 式 系统 会 被 用 来 控制 防 抱 死 制 动 系统 , 另 一 个 用 来 监控 车 辆 的 气 
体 排 放 , 还 有 的 用 于 在 仪表 板 上 显示 信息 。 

注 3 这 人 句 话 的 含义 是 : 已 经 有 很 多 具有 巨大 市 场 潜力 的 新 的 戏 和 人 式 设备 了 : 可 以 被 中 央 计 算 机 
控制 的 调 光 各 和 和 恒温 磊 、 当 小 孩子 或 矮 个 子 的 人 在 的 时 候 不 会 充气 的 智能 气 赛 .掌上 电子 记事 短 和 个 人 
数字 助理 (PDA) 数码 照相 机 和 仪表 导航 系统 。 

TE4 这 人 句 话 的 含义 是 : 如 果 一 个 实时 系统 是 飞机 飞行 控制 系统 的 一 部 分 ,那么 一 个 超期 的 计算 就 
可 能 使 乘客 和 机 组 人 员 的 生命 受到 威胁 。 而 把 这 个 系统 用 在 卫星 通信 环境 下 ,危害 也 许可 以 限制 在 仅 
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一 个 损坏 的 数据 包 。 
TES ”这 名 话 的 含义 是 : 他 必须 保证 软件 和 人 硬件 在 所有 可 能 的 情况 下 都 能 可 靠 工 作 。 


Text B Getting to Know the Hardware 


As an embedded software engineer, you'll have the opportunity to work with many 
different pieces of hardware in your career. In this chapter, I will teach you a simple 
procedure that I use to familiarize myself with any new board. In the process, I'll guide 


you through the creation of a header file that describes the board's most important features 


and a piece of software that initializes the hardware to a known state. #1 


1. Understand the big picture 


Before writing software for an embedded system, you must first be familiar with the 
hardware on which it will run. At first, you just need to understand the general operation of 
the system. You do not need to understand every little detail of the hardware; that kind of 
knowledge will not be needed right away and will come with time. 

Whenever you receive a new board, you should take some time to read whatever 
document® have been provided with it. If the board is an off-the-shelf product, it might 
arrive with a " Users Guide” or “ Programmer's Manual" that has been written with the 
software developer in mind. YY However, if the board was custom designed for your project, 
the documentation might be more cryptic9 or written mainly for the reference9 of the 
hardware designers. Either way, this is the single best place for you to start. 

While you are reading the documentation, set the board itself aside. This will help you 
to focus on the big picture. There will be plenty of time to examine the actual board more 
closely when you have finished reading. Before picking up the board, you should be able to 
answer two basic questions about it; 

e What is the overall purpose of the board? 

e How does data flow through it? 

For example, imagine that you are a member of a modem design team. You are a 
software developer who has just received an early prototype board from the hardware 
designers. Because you are already familiar with modems, the overall purpose of the board 


and the data-flow through it should be fairly obvious to you. The purpose of the board is to 
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send and receive digital data over an analog telephone line. The hardware reads digital data 
from one set of electrical connections and writes an analog version of the data to an 
attached telephone line. *? Data also flows in the opposite direction, when analog data is read 
from the telephone line jack and output digitally. 

Though the purpose of most systems is fairly obvious, the flow of the data might not be. 
I often find that a data-flow diagram is helpful in achieving rapid comprehension9. If you 
are lucky, the documentation provided with your hardware will contain a superset of the 
block diagram you need. However, you might still find it useful to create your own data-flow 
diagram. That way, you can leave out those hardware components that are unrelated to the 
basic flow of data through the system. 

In the case of the Arcom board, the hardware was not designed with a particular 
application in mind. So for the remainder of this chapter, we'll have to imagine that it does 
have a purpose. We shall assume the board was designed for use as a printer-sharing® 
device. A printer-sharing device allows two computers to share a single printer. ¥ 

The user of the device connects one computer to each serial port and a printer to the 
parallel9 port. > Both computers can then send documents to the printer, though only one 
of them can do so at a given time. 

In order to illustrate the flow of data through the printer-sharing device, I’ve drawn 
the diagram in Figure 6-1. (Only those hardware devices that are involved in this application 
of the Arcom board are shown. ) By looking at the block diagram, you should be able to 
quickly visualize the flow of the data through the system. Data to be printed is accepted from 
either serial port, held in RAM until the printer is ready for more data, and delivered to the 
printer via the parallel port. The software that makes all of this happen is stored in ROM. 

Once you've created a block diagram, don't just crumple it up and throw it 
away9. You should instead put it where you can refer to it throughout the project. I 
recommend creating a project notebook or binder with this data-flow diagram on the first 
page. As you continue working with this piece of hardware, write down everything you learn 
about it in your notebook. You might also want to keep notes about the software design and 


implementation. A project notebook is valuable not only while you are developing the 
software , but also once the project is complete. * You will appreciate the extra effort you 
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put into keeping a notebook when you need to make changes to your software, or work with 


similar hardware, months or years later. 
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Figure 6-1 flow of data through the printer-sharing device 


2. Examine the landscape 


It is often useful to put yourself in the processor’s shoes for a while. After all, the 
processor is only going to do what you ultimately® instruct it to do with your software. ™’ 
Imagine what it is like to be the processor; what does the processor’s world look like? If you 
think about it from this perspective®, one thing you quickly realize is that the processor has 
a lot of compatriots®. These are the other pieces of hardware on the board, with which the 
processor can communicate directly. In this section you will learn to recognize their names 
and addresses. 

The first thing to notice is that there are two basic types: memories and peripherals. 
Obviously, memories are for data and code storage and retrieval. “* But you might be 
wondering what the peripherals are. These are specialized hardware devices that either 
coordinate interaction with9 the outside world ( L/O) or perform a specific hardware 
function. For example, two of the most common peripherals in embedded systems are serial 
ports and timers. The former is an I/O device, and the latter is basically just a counter. ? 

Members of Intel's 80x86 and some other processor families have two distinct address 
spaces through which they can communicate with these memories and peripherals. The first 
address space is called the memory space and is intended mainly for memory devices; the 


second is reserved exclusively9 for peripherals and is called the L/O space. However, 
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peripherals can also be located within the memory space, at the discretion of the hardware 
designer. When that happens, we say that those peripherals are memory-mapped®. 

From the processor's point of view, memory-mapped peripherals look and act very 
much like memory devices. However, the function of a peripheral is obviously quite 
different from that of a memory. Instead of simply storing the data that is provided to it, a 
peripheral might instead interpret it as a command or as data to be processed in some way. 
If peripherals are located within the memory space, we say that the system has memory- 
mapped I/O. 

The designers of embedded hardware often prefer to use memory-mapped I/O 
exclusively , because it has advantages for both the hardware and software developers. It is 
attractive to the hardware developer because he might be able to eliminate® the I/O 
space, and some of its associated wires, altogether. This might not significantly reduce the 
production cost of the board, but it might reduce the complexity® of the hardware design. 
Memory-mapped peripherals are also better for the programmer, who is able to use 


pointers, data structures, and unions to interact with the peripherals more easily and 
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efficiently. 
Words 

appreciate vt. &vi. (动词 ) TOR URS RR 
compatriot n. (名 词 ) 同胞 ;伙伴 
complexity n. (名 词 ) 复杂 ,复杂 性 
comprehension n. (名 词 ) 理解 力 
coordinate n. (名 词 ) 坐标 ,同等 的 人 
crumple vt. & vi. (动词 ) 使 扭曲 ,使 月 泪 
cryptic adj. (形容 词 ) 神秘 的 
document n. (名 词 ) 公文 ,文件 ,证 件 
eliminate vt. &vi. (动词 ) 消除 ,根除 ,排除 
exclusively adv. (副词 ) 专门 地 ,排除 其 他 的 
familiarize vt. & vi. (动词 ) 熟悉 
illustrate v. (动词 ) 说 明 ,阐明 
parallel adj. (形容 词 ) 平行 的 ,并 行 的 
perspective n. (名 词 ) 视角 ,观点 ,远景 
plenty adj. (形容 词 ) B ,充足 ,大 量 

& "urna 

D 消除 ,根除 ,排除 

Q 复杂 ,复杂 性 


reference n. (名 词 ) 涉及 , 提 及 


retrieval vt. & vi. (lis) 检索 
ultimately adv. (副词 ) 最 后 ,最 终 
version n. (名 词 ) 版 本 ;译文 
Phrases 
an imperative component of 不 可 或 缺 的 组 成 部 分 
be familiar with 熟悉 
be plenty of 很 多 
crumple up FF HR 
defined as 定义 为 
familiarize with A A 
interaction with 交往 ; 与 …… 相 互 作用 
memory-mapped 内 存 映 射 的 ;存储 映像 的 
printer-sharing 打印 机 共享 
the General Public License 通用 公共 许可 证 的 
throw away 扔 挥 
with the help of 在 …… 的 帮助 下 
He 注 


注 1 这 句 话 的 含义 是 ; 我 将 通过 教 你 创建 一 个 描述 电路 板 的 头 文件 和 一 小 部 分 软件 ,在 这 个 头 文 
件 里 描述 的 是 这 张 板 的 最 重要 特性 ,这 一 小 部 分 软件 把 硬件 初始 化 至 一 个 已 知 状态 。 

注 2 这 人 句 话 的 含义 是 : 如 果 这 个 电路 板 是 从 代 架 上 拿 来 的 标准 产品 ,那么 它 很 可 能 会 有 “用 户 手 
册 ” 或 “程序 员 和 手册”, 里 面 刻 记 着 软件 开发 商 的 名 字 。 

ip3 这 人 句 话 的 含义 是 : 便 件 从 一 组 电源 连接 右上 读 取 数字 信号 ,然后 转换 成 模拟 信号 ,通过 相连 
的 电话 线 进行 传输 。 

注 4 这 人 句 话 的 含义 是 : 一 个 共享 的 打印 机 设备 可 以 允许 两 台 计 算 机 共享 一 个 打印 机 。 

注 5 and a printer to the parallel port 省 略 了 connects ,这 人 句 话 是 一 个 并 列 句 ,通过 and 将 两 句 话 连接 
起 来 。 这 人 句 话 的 含义 是 : 设备 将 一 台 计 算 机 与 每 个 串口 相连 ,将 打印 机 与 并 口 相 连 。 

注 6 not only but also; 不 仅 , 而 且 ;not only 后 面 连接 了 一 个 从 名 ;but also 后 面 也 连接 了 一 个 从 
A), KAWE ME: 项 目 工程 记事 本 对 于 你 开发 一 个 软件 很 重要 ,对 于 项 目 开 发 完成 后 也 是 很 重 
要 的 。 

TET 这 人 句 话 的 含义 是 : 毕 葛 ,这 个 处 理 顺 只 有 当 你 通过 软件 发 出 指令 做 什么 之 后 , 才 决 定做 
1A. 

TES 这 人 句 话 的 含义 是 : 很 显然 ,内 存 是 用 来 存储 数据 .代码 和 检索 的 。 

注 9 the former 是 指 serial ports ;the latter 指 的 是 timers。 这 人 句 话 的 含义 是 ; D] AL, E HX A X AR BEI 
有 两 个 最 常见 的 外 设 : 串口 和 计时 需 。 串 口 是 输 入 输出 设备 ,而 计时 融 仅 指 计时 天 。 
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Associated Reading 


Briet Introduction of Qt 


Qt is defined as a cross platform application. It is a framework which is used in to 
develop application software. This application software is developed with the help graphical 
user interface. This cross platform application is also used in developing non graphical user 
interface programs. Some of the programs which use this application program are Google, 
Adobe Photoshop, Panasonic; Philips etc. This application uses the C++ language. But Qt 
uses a unique code generator with many macros to enhance the language. Qt can also be used 
in many programming language with the help of language bindings. It is used on many 
platforms and is also internationally recognized. This cross platform application was 
developed by Trolltech but they later sold this application to Nokia. The software libraries 
which use this application are advanced component framework, KDELibs, LibQxt etc. 

Qt has always been available through a commercial license which allows the expansion 
of proprietary purposes without any restriction on licensing. In addition, Qt has been steadily 
made open through an increasing number of other free licenses. Currently, Qt is accessible 
under the General Public License (GNU) ; this provision makes it available for utilization for 
both free software and proprietary. Before the 1.45 version, the source code used for Qt was 
published under free Qt license. This was not really viewed as amenable with the free 
software description of the Free Software Foundation and neither by the Open Source 
principle as described by the Open Source Initiative. The reason behind this was that it did 
not allow the distribution of other modified versions. 

In 1998, many controversies broke out when it was acknowledged that KDE’s KDE 
software compilation would undoubtedly become the leading desktop setting especially for 
Linux. Owing to the fact that it was founded on a Qt basis, many professionals who took part 
in the free software movement became apprehensive that an imperative component of one of a 
leading operating system would become proprietary. 

Along with the release of the 2.0 version of the toolbox, the license was transformed to 
the QPL ( Q Public License). QPL was a free software license but it was considered 
incompatible with GPL by the Free Software Foundation. Trolltech and KDE then sought out 
many compromises which would imply that Qt will not be regarded by any license more 
restrictive than QPL, even in the case Trolltech goes bankrupt. This major issue led to the 
invention of the free Qt foundation by KDE. 

Qt is defined as a cross platform application. It is a framework which is used in to 
develop application software. This application software is developed with the help graphical 
user interface. This cross platform application is also used in developing non graphical user 
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interface programs. Some of the programs which use this application program are Google, 
Adobe Photoshop, Panasonic, Philips etc. This application uses the C++ language. But Qt 
uses a unique code generator with many macros to enhance the language. Qt can also be used 
in many programming language with the help of language bindings. It is used on many 
platforms and is also internationally recognised. This cross platform application was 
developed by Trolltech but they later sold this application to Nokia. The software libraries 


which use this application are advanced component framework, KDELibs, LibQxt etc. 
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Unit 7 Computer Network 


Text A Internet Protocol Suite 


The Internet Protocol Suite is the set of communications protocols used for the Internet 
and other similar networks. It is commonly also known as TCP/IP, named from two of the 
most important protocols in it; the Transmission Control Protocol (TCP) and the Internet 
Protocol (IP), which were the first two networking protocols defined in this standard. 
Modern IP networking represents a synthesis of several developments that began to evolve 
in the 1960s and 1970s, namely the Internet and local area networks, which emerged during the 
1980s, together with the advent® of the World Wide Web in the early 1990s. *! 

The Internet Protocol Suite, like many protocol suites, is constructed as a set of 9 
layers. Each layer solves a set of problems involving the transmission of data. In particular, 
the layers define the operational scope of the protocols within. 

Often a component of a layer provides a well-defined® service to the upper layer 
protocols and may be using services from the lower layers. Upper layers are logically 
closer to the user and deal with more abstract data, relying on lower layer protocols to 
translate® data into forms that can eventually be physically transmitted. 

The TCP/IP model consists of four layers. From lowest to highest, these are the Link 
Layer, the Internet Layer, the Transport Layer, and the Application Layer. 


1. History 


The Internet Protocol Suite resulted from research and development conducted by the 
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传输 

标准 

综合 

演变 ;进化 
出 现 ; 到 来 
组 成 
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明确 定义 的 
逻辑 上 
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Defense Advanced Research Projects Agency (DARPA) in the early 1970s. In the spring of 
1973, Vinton Cerf, the developer of the existing® ARPANET Network Control Program 
(NCP) protocol, joined Kahn to work on open-architecture® interconnection models 
with the goal of designing the next protocol generation for the ARPANET. 

By the summer of 1973, Kahn and Cerf had worked out a fundamental® 
reformulation9 , where the differences between network protocols were hidden® by using 
a common internetwork protocol, and, instead of® the network being responsible for 
reliability9 , as in the ARPANET, the hosts became responsible. 

In 1975, a two-network TCP/IP communications test was performed between Stanford 
and University College London ( UCL). In November, 1977, a three-network TCP/IP test 
was conducted between sites in the US, UK, and Norway. Several other TCP/IP 
prototypes9 were developed at multiple research centers between 1978 and 1983. The 
migration9 of the ARPANET to TCP/IP was officially completed on January 1, 1983, 
when the new protocols were permanently9 activated. 

In March 1982, the US Department of Defense declared TCP/IP as the standard for all 
military computer networking. In 1985, the Internet Architecture Board held a three day 


workshop on TCP/IP for the computer industry, attended by 250 vendor representatives , 


promoting the protocol and leading to its increasing commercial use. ™ 


2. Layers in the Internet protocol suite 


The TCP/IP suite uses encapsulation9 to provide abstraction of protocols and 


services. Such encapsulation usually is aligned with the division of the protocol suite into 


layers of general functionality. "afi general, an application (the highest level of the model) 
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uses a set of protocols to send its data down the layers, being further encapsulated at each 
level. ** 

This may be illustrated9 by an example network scenario, in which two Internet 
host computers communicate across local network boundaries constituted by their 


internetworking gateways ( routers ) shown in Figure 7-1. 


Network Connections 


Application | 一 一 一 一 一 一 一 一 一 一 一 一 一 一 Application 
> 


— 


Satellite 


Figure 7-1 TCP/IP stack operating on two hosts connected via two routers and 


the corresponding layers used at each hop 


The functional groups of protocols and methods are the Application Layer, the 
Transport Layer9, the Internet Layer9, and the Link Layer9. This model was not 
intended to be a rigid reference model into which new protocols have to fit in order to® 
be accepted as a standard. 55 The encapsulation of application data descending through the 
protocol stack is shown in Figure 7-2. 

The following Table 7-1 provides some examples of the protocols grouped in their 
respective layers. 
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Figure 7-2 Encapsulation of application data descending through the 


protocol stack 


Table 7-1 Some examples of the protocols in their respective layers 


DNS, TFTP, TLS/SSL, FTP, Gopher, HTTP, IMAP, IRC, NNTP, POP3, SIP, 


SMTP, SMPP, SNMP, SSH, Telnet, Echo, RTP, PNRP, rlogin, ENRP 


Application 
Routing protocols like BGP and RIP which run over TCP/UDP, may also be considered 
part of the Internet Layer 

Transport TCP, UDP, DCCP, SCTP, IL, RUDP, RSVP 
OSPF for IPv4 was initially considered IP layer protocol since it runs per IP-subnet, but 
has been placed on the Link since RFC 2740 

Link ARP, RARP, OSPF ( IPv4/IPv6) , IS-IS, NDP 


3. Implementations 


Most computer operating systems in use today, including all consumer-targeted® 


systems, include a TCP/IP implementation. * Minimally acceptable implementation 


includes implementation for (from most essential to the less essential) IP, ARP, ICMP, 


UDP, TCP and sometime IGMP. 


Most of the IP implementations are accessible to the programmers using socket 


abstraction ( usable also with other protocols) and proper API for most of the operations. 


This interface is known as BSD sockets and was used initially in C. * 


Words 


abstract adj. (形容 词 ) 抽象 的 


消费 对 象 
执行 
要 点 
套 接 字 
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activated adj. (和 形容词) 有 活性 的 ,被 激活 的 


align vt. &vi. (动词 ) Xt FF 
constitute vt. & vi. (Mia) 组 成 
construct n. (名 词 ) 构想 ,概念 
encapaulation n. (名 词 ) 封装 
essential n. (474) 要 点 
evolve vt. & vi. (动词 ) 出 现 ; 到 来 
existing adj (形容 词 );v. (动词 ) 目前 的 ;现存 的 ; 存在 (exist 的 现在 
分 词 ) 

fundamental adj. (形容 词 ) 基本 的 
generation n. (名 词 ) 产生 ;一 代 
hidden adj. (形容 词 ) 难以 发 现 的 ,隐藏 
illustrate vt. & vi. (Mia) Bt AA, D] HH 
initially adv. (形容 词 ) 最 初 
interconnection n. (名 词 ) 互联 
logically adv. (副词 ) 次 辑 上 
migration n. (474) 迁移 
multiple adj. (形容 词 ) 多 重 的 
operational adj. (形容 词 ) 可 操作 的 ,运行 的 
permanently adv. (副词 ) 永存 地 ,不 变 地 
physically adv. (副词 ) 身体 上 ,身体 上 地 ,物理 地 身体 上 
promote vt. &vi. (动词 ) 促进 
protocol n. (名 词 ) 协议 
prototype n. (名 词 ) 原型 
reformulation n. (474) 再 形成 ; 重 逆 
reliability n. (名 词 ) LE c: 
rigid adj. (形容 词 ) 严格 的 
scenario n. (474) 情景 
socket n. (474) Es Ns TH 
standard n. (474) 标准 
Synthesis n. (名 词 ) 综合 
translate vt. &vi. (动词 ) 翻译 ,转换 
transmission n. (名 词 ) 传输 
vendor n. (474) 卖主 

Phrases 
a set of 一 套 ;一 组 ;一 副 
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consumer-targeted 消费 对 象 


in order to 为 了 
instead of 代 着 ;不 是 …… 而 是 …… 
open-architecture 开放 式 体系 结构 
the internet layer 网 络 层 
the link layer 链 路 层 
the transport layer 传输 层 
Exercises 


[Ex1] Answer the questions according to the text: 


(1) What is the Internet Protocol Suite? 

(2) What are the most important protocols of Internet Protocol Suite? 

(3) What does the TCP/IP model consist of? 

(4) When did the Internet Protocol Suite result from research and development 
conducted by DARPA? 


(5) How does an application send its data down the layers? 
[Ex2] Translate into Chinese: 


(1) The Internet Protocol Suite is the set of communications protocols used for the 
Internet and other similar networks. 

(2) Upper layers are logically closer to the user and deal with more abstract data, 
relying on lower layer protocols to translate data into forms that can eventually be physically 
transmitted. 

(3) The Internet Protocol Suite resulted from research and development conducted by 
the Defense Advanced Research Projects Agency (DARPA) in the early 1970s. 

(4) Several other TCP/IP prototypes were developed at multiple research centers 
between 1978 and 1983. 

(5) The TCP/IP suite uses encapsulation to provide abstraction of protocols and 
services. 

(6) This model was not intended to be a rigid reference model into which new protocols 
have to fit in order to be accepted as a standard. 

(7) Most computer operating systems in use today, including all consumer-targeted 
systems, include a TCP/IP implementation. 

(8) Most of the IP implementations are accessible to the programmers using socket 
abstraction ( usable also with other protocols) and proper API for most of the operations. 
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[Ex3] Choose the best answer: 


(1) It is commonly also known as TCP/IP, named from two of the most important 
protocols in it; the Transmission Control Protocol and 
A. an identifier B. the Internet Protocol ( IP) 


C. an array D., TIP 
(2) The TCP/IP model consists of layers. 
A. three B. six 
C. four D. two 
(3) The functional groups of protocols and methods are , the Transport 


Layer, the Internet Layer, and the Link Layer. 
A. ActiveX B. XML 
C. HTML Layer D. the Application Layer 
(4) Most computer operating systems in use today, including all consumer-targeted 
systems, include a TCP/IP 
A. plan B. requirement 
C. implementation D. design 
(5) This passage is mainly talking about 
A. Internet Protocol Suite B. a control 


C. pipelining D. producing 


He 注 

ik 1 Mordern IP networking 4: 3: i& ; represents 是 谓 霹 ;several develepments 是 宾语 ;that 引导 了 一 
个 宾语 从 句 ;began 是 从 句 谓 语 ;namely 修饰 Mordern IP networking; Which 引导 一 个 主语 从 名 emerged 
是 谓语 ;together with 修饰 主语 ;Mordern IP networking 属于 宾语 。 

TE2 这 句 话 的 含义 是 : 1985 年 ,因特网 架构 理事 会 举行 了 一 个 为 期 3 天 由 250 家 厂商 代表 参加 的 
关于 计算 产业 使 用 TCP/IP 的 工作 会 议 , 帮 助 推广 协议 并 且 引 领 它 日 渐 增 长 的 商业 应 用 。 

TE3 这 人 句 话 的 含义 是 : 这 些 封包 通常 与 被 分 离 的 协议 层 的 一 般 功 能 对 齐 。 

注 4 这 人 句 话 的 含义 是 : 一 般 来 说 ,应 用 层 使 用 一 组 协议 发 送 数据 到 下 层 , 这 样 能 更 进一步 地 在 每 
一 层 中 封装 数据 。 

TES 这 有 段 话 的 含义 是 : 这 些 实用 的 协议 组 和 方法 是 应 用 层 传输 层 网际 层 和 网 络 接口 层 。 这 个 
模型 并 不 是 一 个 严格 的 参考 模型 , 它 并 没有 要 求 新 协议 必须 接受 它 为 新 的 标准 。 

ipe 这 人 句 话 的 含义 是 : 在 当今 使 用 的 大 部 分 操作 系统 中 ,包括 所 有 的 用 户 系统 ,都 含有 TCP/IP 
实现 。 

注 7 这 句 话 的 含义 是 : SIP 操作 都 能 通过 程序 员 使 用 抽象 套 接 字 及 合适 的 API 实现 大 部 分 的 
操作 。 这 个 接口 就 是 BSD 套 接 ,并 且 它 最 初 使 用 于 C 语言 中 。 


Text B Cloud Computing 


1. What is cloud computing 


Cloud Computing is a resource delivery and usage model; it means get resource 
( Hardware, software) via network. The network of providing resource is called * Cloud’. 
The hardware resource in the ‘Cloud’ seems scalable9 infinitely and can be used 
whenever. 

Cloud Computing refers to both the applications delivered as services over the Internet 
and the hardware and systems software in the datacenters that provide those services. The 
services themselves have long been referred to as Software as a Service ( SaaS) , so we use 


that term9. The datacenter hardware and software is what we will call a Cloud. 
2. New application opportunities 


(1) Mobile interactive applications. Tim O'Reilly believes that “the future belongs to 
services that respond in real time to information provided either by their users or by 
nonhuman sensors. " Such services will be attracted to the cloud not only because they 
must be highly available, but also because these services generally rely on large data sets 
that are most conveniently hosted in large datacenters. =! This is especially the case for 
services that combine® two or more data sources or other services, e. g. , mash-ups. While 
not all mobile devices enjoy connectivity to the cloud 100% of the time, the challenge of 
disconnected operation has been addressed successfully in specific application 
domains, so we do not see this as a significant obstacle to the appeal of mobile 
applications. dis 

(2) Parallel batch processing. Although thus far we have concentrated on using 


Cloud Computing for interactive SaaS, Cloud Computing presents a unique opportunity for 
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batch-processing and analytics jobs that analyze terabytes® of data and can take hours to 
finish. If there is enough data parallelism® in the application, users can take advantage of 
the cloud's new “cost associativity” : using hundreds of computers for a short time costs the 
same as using a few computers for a long time. For example, Peter Harkins, a Senior 
Engineer at The Washington Post, used 200 EC2 instances ( 1407 server hours) to convert 
17,481 pages of Hillary Clinton's travel documents into a form more friendly to use on the 
WW within nine hours after they were released. Programming abstractions such as 
Google's Map Reduce and its open-source counterpart Hadoop allow programmers to 
express such tasks while hiding the operational complexity9 of choreographing® parallel 
execution across hundreds of Cloud Computing servers. Indeed, Cloudera is pursuing 
commercial opportunities in this space. Again, using Gray's insight, the cost/benefit analysis 
must weigh the cost of moving large datasets into the cloud against the benefit of potential 
speedup in the data analysis. When we return to economic models later, we speculate that 
part of Amazon's motivation to host large public datasets for free may be to mitigate9 the 
cost side of this analysis and thereby attract users to purchase Cloud Computing cycles near 
this data. 

(3) The rise of analytics. A special case of compute-intensive batch processing is 
business analytics. While the large database industry was originally dominated by transaction 
processing, that demand is leveling off. A growing share of computing resources is now 
spent on understanding customers, supply chains, buying habits, ranking, and so on. 
Hence, while online transaction volumes will continue to grow slowly, decision support is 
growing rapidly, shifting the resource balance in database processing from transactions to 
business analytics. 

(4) Extension of compute-intensive desktop applications. The latest versions of the 


mathematics software packages MATLAB and Mathematica are capable of using Cloud 
Computing to perform expensive evaluations. 53 Other desktop applications might similarly 
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benet from seamless extension into the cloud. Again, a reasonable test is comparing the 
cost of computing in the Cloud plus the cost of moving data in and out of the Cloud to the 
time savings from using the Cloud. ** Symbolic mathematics involves a great deal of 
computing per unit of data, making it a domain worth investigating. An interesting alternative 
model might be to keep the data in the cloud and rely on having sufficient9 bandwidth to 
enable suitable visualization and a responsive GUI back to the human user. Offline image 
rendering or 3D animation might be a similar example: given a compact description of the 
objects in a 3D scene and the characteristics of the lighting sources, rendering the image is an 
embarrassingly9 parallel9 task with a high computation-to-bytes ratio. 

(5) "Earthbound" applications. Some applications that would otherwise be good 
candidates for the cloud's elasticity9 and parallelism may be thwarted by data movement 
costs, the fundamental latency® limits of getting into and out of the cloud, or both. For 
example, while the analytics associated with making long-term financial decisions are 
appropriate for the Cloud, stock trading that requires microsecond precision is not. Until the 
cost ( and possibly latency ) of widearea data transfer decrease ( see Section 7), such 
applications may be less obvious candidates for the cloud. 

i. Cloud Computing Economics 

In deciding whether hosting a service in the cloud makes sense over the long term, we 
argue that the fine-grained® economic models enabled by Cloud Computing make tradeoff 
decisions more fluid, and in particular the elasticity offered by clouds serves to transfer risk. 

As well, although hardware resource costs continue to decline, they do so at variable 
rates; for example, computing and storage costs are falling faster than WAN costs. Cloud 
computing can track these changes-and potentially pass them through to the customer-more 
effectively than building one's own datacenter, resulting in a closer match of expenditure 
to actual resource usage. 


In making the decision about whether to move an existing service to the cloud, one 


must additionally examine the expected average and peak resource utilization, especially if the 


准确 无 误 的 ;无 颖 的 
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application may have highly variable spikes® in resource demand; the practical limits on 
real-world utilization of purchased equipment; and various operational costs that vary 
depending on the type of cloud environment being considered. *° 

ii. About The Clouds of Tomorrow 

The long dreamed vision of computing as a utility is finally emerging. The elasticity of a 
utility matches the need of businesses providing services directly to customers over the 
Internet, as workloads can grow ( and shrink) far faster than 20 years ago. It used to take 
years to grow a business to several million customers-now it can happen in months. 

Some question whether companies accustomed to high-margin9 businesses, such as ad 
revenue from search engines and traditional packaged software, can compete in Cloud 
Computing. First, the question presumes that Cloud Computing is a small margin business 
based on its low cost. Given the typical utilization of medium-sized datacenters, the potential 
factors of 5 to 7 in economies of scale, and the further savings in selection of cloud 
datacenter locations, the apparently low costs offered to cloud users may still be highly 
profitable to cloud providers. 59 Second, these companies may already have the datacenter, 
networking, and software infrastructure in place for their mainline businesses, so Cloud 


Computing represents the opportunity for more income at little extra cost. 


Words 
abstraction n. (名 词 ) 抽象 
analytics n. (474) 分 析 学 
available adj. (形容 词 ) 可 用 的 ;可 获得 的 
choreograph vt. &vi. (动词 ) 筹划 , 编 舞 
combine vt. &vi. (7a ) 结合 
complexity n. (名 词 ) 复杂 度 
concentrate vt. &vi. (Mia) 集中 ,聚集 
connectivity n. (名 词 ) 连通 性 
convert vt. &vi. (动词 ) 转变 ;改变 
disconnected adj. (形容 词 ) 不 连贯 的 
domain n. (474) DX Jak, ; Bi 
elasticity n. (名 词 ) 灵活 性 ;伸缩 性 
embarrassingly adv. (副词 ) A> JE HOt Ht, , E A HE HE Ht, 
o itt 
e 高 利润 的 
e 选择 
© 基础 结构 ,基础 设施 


expenditure 
fine-grain 
high-margin 
infrastructure 
latency 
mathematics 
mitigate 
nonhuman 
obstacle 
parallelism 
release 
rendering 
scalable 
seamless 
selection 
shift 
speculate 
spike 
sufficient 
terabyte 
term 

thwart 
usage 


visualization 


in making the decision 
leveling off 
open-source 
symbolic mathematics 


the appeal of 


批 注 


TEL 这 人 句 话 的 含义 是 : 这 种 服务 是 非常 ; 
型 数据 中 心 妥 善 存储 大 量 数据 。 


n. (名 词 ) 花费 ;支出 
adj. (形容 词 ) 细 粒 度 的 
adj. (形容 词 ) 高 利润 的 
n. (名 词 ) 基础 结构 ,基础 设施 
n. (名 词 ) 潜伏 物 ; 潜在 因素 
n. (名 词 ) 数学 
vt. &vi. (动词 ) 使 缓和 和 ;减轻 
adj. (形容 词 ) 非 人 类 的 
n. (名 词 ) Ix 
n. (474) 平行 度 
vt. & vi. (动词 ) 发 布 ;释放 
n. (名词) je 2 
adj. (形容 词 ) 可 攀登 的 ;可 升级 的 
adj. (形容 词 ) 准确 无 误 的 ;无 颖 的 
n. (名 词 ) 选择 
vt. &vi. (动词 ) 转移 ;移动 ; 偏 移 
vt. &vi. (动词 ) 猜测 ,推测 
n. (名 词 ) RIRH 
adj. (形容 词 ) 充足 的 ,足够 的 
n. (名 词 ) JE JS 56 A EU 
n. (名 词 ) 专门 名 词 ,术语 
vt. &vi. (动词 ) [E F% 
n. (名 词 ) 使 用 、 用 法 
n. (名 词 ) 可 视 化 
Phrases 
在 做 决定 
开平 
开源 的 
符号 数学 
LF BY 


合 云 的 ,因为 它们 不 仅 要求 高 可 用 性 ,而 且 通 第 需要 大 


注 2 这 人 句 话 的 含义 是 : 虽然 不 是 所 有 的 移动 设备 都 能 保证 一 直 与 云 设 备 连接 ,但 是 脱 机 状态 下 的 


Ua 


处 理 在 具体 应 用 领域 中 已 经 讨论 过 ,所 以 这 里 不 认为 这 是 影响 移动 应 用 的 重大 障碍 。 

ip3 这 人 句 话 的 含义 是 : 最 新 版 本 的 数学 软件 包 MATLAB 和 Mathematica 可 以 通过 云 计算 进行 复 
2RR PE T A . 

ip4 重申 ;一 个 合理 的 测试 是 比较 利用 云 计算 的 成 本 ,以 及 数据 传输 的 费用 与 利用 云 计算 节省 的 
时 间 。 

注 5 在 决定 是 否 将 现 有 服务 转向 云 计算 时 ,必须 仔细 考虑 预期 的 平均 资源 使 用 和 峰值 资源 使 用 
情况 ,特别 是 在 应 用 具有 对 资源 需求 高 可 变性 情况 下 ,必须 考虑 购买 设备 的 实际 使 用 情况 以 及 在 不 同 云 
环境 下 的 运行 操作 成 本 。 

iE6 Given 分 词 短语 为 独立 结构 成 分 ;may still be 为 谓语 。 这 人 句 话 的 含义 是 : 只 要 考虑 一 个 中 等 
规模 数据 中 心 的 利用 率 ,考虑 将 其 扩大 5 ~7 倍 ,并 考虑 未 来 对 云 计 算数 据 中 心地 点 的 选择 ,虽然 云 用 户 
支付 的 费用 不 高 ,但 最 终 云 服 务 提供 商 仍 可 获得 可 观 的 利润 。 


Associated Reading 


Edraw Network Diagram v5.6 


EDraw Network Diagrammer 1s a professional network diagramming software with rich 
examples and templates. Easy to draw detailed physical, logical, Cisco and network 
architecture diagrams, using a comprehensive set of network and computer equipment shapes 


shown as Figure 7-3. 


d / M urn to Pent * BGowing~ Bi coo ~ 


X E | "usendto sack Baton’ dh shape n ” 
tío @ | PRotate eH - MDstrbuts - EZ shape Outline - 
5 Arrange L Styles Ts 


Text Connector 


Basic Tools 


0 st h20 i0, [e [o [60 
mdi MU Un 


Figure 7-3 Edraw network diagram v5. 6 


Pre-drawn network diagram icons representing computers, network devices plus smart 


connectors help design diagram network, create accurate network diagrams and 
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documentation to be used in your network diagram project. Abundant network diagram 
templates, network diagram symbols and network diagram examples will help to quickly 
create most common network diagrams. Intuitive interface helps to create accurate diagrams 
in a minutes. Just drag and drop pre-drawn shapes representing computers and network 
devices. Double click and set equipment data. Create detailed physical, logical and network 


architecture diagrams, using a comprehensive set of network and computer equipment shapes. 
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Unit 8 Data Structure 


Text A Data Structures? and Algorithms? in Java 


Once you've learned to program, you run into real-world problems that require more 
than a programming language alone to solve. *' Data Structures and Algorithms in Java is a 


gentle immersion into the most practical® ways to make data do what you want it 
to do. ¥ 


1. Overview of data structures 


Another way to look at data structures is to focus on their strengths and weaknesses. In 
this section we'll provide an overview, in the form of a table as Table 8-1, of the major 


data storage structures we'll be discussing. 


Table 8-1 Characteristics of Data Structures 


Data Structure Advantages Disadvantages 
Quick insertion, very fast access if index . . 
known 
Ordered array Quicker search than unsorted array Slow insertion and deletion, fixed size 
Stack Provides last-in, first-out access Slow access to other items 
Linked list Quick insertion, quick deletion Slow search 
. Quick search, insertion, deletion ( if tree f . . - 
Binary tree i Deletion algorithm is complex 
remains balanced ) 


Heihi dun Quick search, insertion, deletion. Tree andis 


always balanced 


tse Very fast access if key known. | Slow deletion, access slow if key not 


Fast insertion known, inefficient memory usage? 
Graph Models real-world situations Some algorithms are slow and complex '* 


ooc0co0c0e0 
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2. Overview of algorithms 


Many of the algorithms we'll discuss apply directly to specific data structures. For most 
data structures, you need to know how to 

(1) Insert a new data item. 

(2) Search for a specified item. 

(3) Delete a specified item. 

You may also need to know how to iterate through all the items in a data structure, 
visiting each one in turn so as to display it or perform some other action on it. One important 
algorithm category 9 is sorting. There are many ways to sort data, The concept of recursion 


is important in designing certain algorithms. 
3. Object-Oriented9 programming 


OOP was invented because Procedural® languages, such as C, Pascal, and BASIC, 
were found to be inadequate® for large and complex programs. Why was this? 

The problems have to do with the overall organization of the program. Procedural 
programs are organized by dividing the code into functions ( called procedures or subroutines 
in some languages). *' Groups of functions could form larger units called modules or files. 
Crude Organizational Units One difficulty with this kind of function-based organization was 
that it focused on functions at the expense of data. There weren't many options when it came 
to data. To simplify slightly, data could be local to a particular function or it could be 
global—accessible® to all functions. There was no way (at least not a flexible way) to 
specify that some functions could access a variable and others couldn't. This caused 
problems when several functions needed to access the same data. To be available to more 
than one function, such variables had to be global, but global data could be accessed 
inadvertently9 by any function in the program. 5$ This leads to frequent programming 
errors. What was needed was a way to fine-tune data accessibility, allow in variables to be 


available to functions with a need to access it, but hiding it from others. 
4. Objects in a nutshell 


From the idea of objects arose in the programming community as a solution to the 


分 类 ,类 别 
面向 对 象 的 

过 程 的 

不 满意 的 ,不 足 的 
可 以 访问 的 

变量 

不 经 意 的 ,随意 的 
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problems with procedural languages. 


(1) Objects 


This new entity, the object, solves several problems simultaneously. Not only 


does a programming object correspond more accurately9 to objects in the real world, it also 


solves the problem engendered by® global data in the procedural model. '? 


(2) Classes 


You might think that the idea of an object would be enough for one programming 
revolution , but there's more. *'" Early on, it was realized that you might want to make 
several objects of the same type. Maybe you're writing a furnace control program for an 
entire apartment house, for example, and you need several dozen thermostat objects9 in 


your program. It seems a shame to go to the trouble of specifying each one separately®. 


Thus, the idea of classes was born. 


accessible 
accurately 
category 
characteristic 
entity 
immersion 
inadequate 
inadvertently 
orient 
practical 
procedural 
revolution 
separately 
simultaneously 


structure 
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Words 


adj. (#74) 
adv. (副词 ) 


n. (名 词 ) 
n. (名 词 ) 
n. (名 词 ) 
n. (名 词 ) 


adj. (形容 词 ) 
adv. (副词 ) 
adj. (形容 词 ) 
adj. (和 形容词) 
adj. (形容 词 ) 
n. (474) 
adv. (副词 ) 
adv. (副词 ) 
n. (474) 


可 以 访问 的 
准确 地 

分 类 ,类别 
特性 ,特点 


wo od IRR cH 
WLI ; x 1x x 


不 满意 的 ,不 足 的 


不 经 意 


面向 …… 的 ,朝向 


实用 的 
过 程 的 
革命 

分 别 地 
同时 地 
结构 体 


variable n. (名 词 ) | 数 ] 变 量 


Phrases 
be inadequate for 不 满意 的 ,不 足 的 
engendered by 由 ……… 产生 
furnace control program 温 控 的 程序 
in the form of pee 的 形式 
thermostat objects 温 控 器 对 象 
Exercises 


[Ex1] Answer the questions according to the text: 


(1) What are the advantages and disadvantages of Array? 

(2) What are the advantages and disadvantages of Binary Tree? 
(3) What is algorithm? 

(4) What's the problem with Procedural Languages? 

(5) What are Object and Class? 


[Ex2] Translate into Chinese: 


(1) Data Structures and Algorithms in Java is a gentle immersion into the most practical 
ways to make data do what you want it to do. 

(2) The concept of recursion is important in designing certain algorithms. 

(3) Groups of functions could form larger units called modules or files. 

(4) Not only does a programming object correspond more accurately to objects in the 
real world, it also solves the problem engendered by global data in the procedural model. 

(5) Global data could be accessed inadvertently by any function in the program. 

(6) Linked lists are probably the second most commonly used general-purpose storage 
structures after arrays. 

(7) The linked list is a versatile mechanism suitable for use in many kinds of general- 
purpose databases. 

(8) For some kinds of hash tables, performance may degrade catastrophically when the 
table becomes too full. 


[Ex3] Choose the best answer: 


(1) in Java is a gentle immersion into the most practical ways to make data 
do what you want it to do. 
A. Data analysis B. Requirement 
C. Data Structures and Algorithms D. Design 
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(2) Which is the Array's advantage 
A. Provides last-in, first-out access 
B. Quick insertion, very fast access if index known 
C. Quicker search than unsorted array 


D. Models real-world situations 


(3) OOP was invented because procedural languages, such as , Pascal, and 
BASIC. 

A. C B. C++ C. CUT D. ASP 

(4) The is an entity to solve several problems simultaneously. 
A. Object B. Class C. Method D. None 

(5) are organized by dividing the code into functions. 
A. Parallel programs B. Procedural programs 
C. Structure programs D. None 

批 it 


注 1 这 人 句 话 的 含义 是 : 当 你 学 习 编 程 的 时 候 , 你 遇 到 的 现实 问题 需要 不 只 一 种 编程 语言 才 可 以 得 
到 解决 。 

注 2 这 人 句 话 的 含义 是 : 基于 Java 的 数据 结构 与 算法 是 把 数据 按 你 想 要 的 方式 存储 的 最 实用 的 
Jis 

注 3 这 行 的 含义 是 : 数组 的 优点 是 搬入 快 ,如 果 知 道 索引 ,可 以 非 凋 快速 地 存 取 。 缺 点 是 查找 慢 ， 
删除 慢 , 定 长 。 

注 4 这 行 的 含义 是 : 二 义 树 的 优点 是 查找 .插入 及 删除 (如 果树 保持 了 平衡 ) 快 速 。 缺 点 是 删除 算 
法 很 复杂 。 

TES 这 行 的 含义 是 : 哈 硕 表 的 优点 是 如 果 知 道 主 键 , 访 问 很 快 ,快速 地 插入 。 缺 点 是 删除 慢 , 如 果 
不 知道 主键 ,那么 内 存 的 利用 率 将 很 低 。 

ibo 这 行 的 含义 是 : 图 的 优点 是 对 现实 的 情形 进行 建 模 。 缺 点 是 有 些 算 法 很 慢 ,很 复杂 。 

TET 这 人 句 话 的 含义 是 : 进程 程序 把 代码 按 功能 进行 划分 。 

注 8 global data 为 主语 ;by any function in the program 为 方式 状语 ;To be available to more than one 
function 表示 目的 ;这 人 句 话 的 含义 是 : 为 了 获得 更 多 的 功能 ,有 些 变量 就 设置 为 全 局 变量 ,但 是 全 局 变量 
可 以 被 程序 中 的 任何 一 个 图 数 访问 。 

注 9 这 人 句 话 的 含义 是 : 对 象 编 程 方法 不 仅 更 精确 地 对 象 对 应 于 现实 世界 中 的 对 象 ,而 且 还 解决 了 
过 程 模型 中 全 局 数据 产生 的 问题 。 

注 10 这 人 句 话 的 含义 是 : 你 可 能 认为 对 象 的 概念 对 编程 革命 已 经 足够 了 ,但 实际 上 还 不 够 。 


Text B The Introduction of Two 
Important Data Structures 


In this part we will take a brief introduction about two important data structures, Linked 


list and Hash table, which will make it effective to search or store the data. 
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1. Linked? list 


We saw that arrays had certain disadvantages as data storage structures. In an unordered 
array, searching is slow, whereas in an ordered array, insertion is slow. El In both kinds of 
arrays deletion is slow. Also, the size of an array can't be changed after it's created. In this 
part we'll look at a data storage structure that solves some of these problems: the linked list. 

Linked lists are probably the second most commonly used general-purpose storage 
structures after arrays. The linked list is a versatile mechanism suitable for use in many 
kinds of general-purpose databases. It can also replace an array as the basis for other storage 
structures such as stacks and queues. In fact, you can use a linked list in many cases where 
you use an array ( unless you need frequent random access to individual items using an 
index). Linked lists aren't the solution to all data storage problems, but they are surprisingly 
versatile and conceptually9 simpler than some other popular structures such as trees. ? 
We'll investigate their strengths and weaknesses as we go along. In this section we will 


refer to two very useful data structure. 
2. Links 


In a linked list, each data item is embedded in a link. A link is an object of a class 
called something like Link. Because there are many similar links in a list, it makes sense to 
use a separate class for them, distinct from the linked list itself. Each link objects 
contains a reference ( usually called next) to the next link in the list. A field in the list itself 
contains are reference to the first link. Here's part of the definition of a class Link. It 


contains some data and a reference to the next link. 


class Link 

{ 

public int ilata; / /data 

public double dData; //data 

public Link next; //reference to next link 


) 


This kind of class definition is sometimes called self-referential because it contains a 


field—called next in this case—of the same type as itself. te 


链接 的 

易 变 的 ,灵活 的 
机 制 

随机 存 取 
概念 上 的 
探讨 ,投入 
不 同 的 
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3. Hash? tables 


A hash table is a data structure that offers very fast insertion and searching. When you 
first hear about them, hash tables sound almost too good to be true. No matter how many 
data items there are, insertion and searching (and sometimes deletion) can take close to® 
constant time; O(1) in Big O notation. '? In practice this is just a few machine instructions. 
For a human user of a hash table this is essentially instantaneous. It's so fast that 
computer programs typically use hash tables when they need to look up tens of thousands of 
items in less than a second (as in spelling checkers). Hash tables are significantly9 faster 
than trees Not only are they fast, hash tables are relatively easy to program. Hash tables 
do have several disadvantages. They're based on arrays, and arrays are difficult to expand 
once they've been created. For some kinds of hash tables, performance may degrade 
catastrophically® when the table becomes too full, so the programmer needs to have a 
fairly accurate idea of how many data items will need to be stored ( or be prepared to 
periodically® transfer data to a larger hash table, a time-consuming? process). jisi 

Also, there's no convenient way to visit the items in a hash table in any kind of order 
(such as from smallest to largest). If you need this capability, you'll need to look 


elsewhere. However, if you don't need to visit items in order, and you can predict in 


advance the size of your database, hash tables are unparalleled in@ speed and 


convenience. 


Words 


catastrophically adv. (副词 ) 严重 地 
conceptually adv. (副词 ) 概念 上 地 
degrade vt. &vi. (动词 ) T 
distinct adj. (形容 词 ) 不 同 的 
essentially adv. (副词 ) 本 质 上 


哈 希 
接近 ; 趋 近 
本 质 上 
相当 的 ,有 意义 的 
相对 的 
执行 ,性 能 
下 降 
严重 地 
阶段 性 地 
耗 时 的 
不 可 匹配 的 
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hash n. (名 词 ) 蛤 希 


investigate vt. & vi. (动词 ) 探讨 ,投入 

linked adj. (形容 词 ) 连接 的 

mechanism n. (名 词 ) 机 制 

performance n. (名 词 ) 执行 ,性 能 

periodically adv. (副词 ) 阶段 性 地 

relatively adv. (副词 ) 相对 地 

significantly adv. (副词 ) 相当 地 ,有 意义 地 

time-consuming adj. (形容 词 ) 耗 时 的 

versatile adj. (形容 词 ) 易 变 的 ,灵活 的 
Phrases 

random access 随机 存 取 

take close to 接近 

unparalleled in 不 可 匹配 的 

round-robin 时 间 片 轮转 

blocks of 许多 块 

scattered throughout 散布 在 

批 ox 


注 1 这 人 句 话 的 含义 是 : 在 无 排序 的 数组 中 ,数据 查找 速度 较 慢 ,而 在 有 序数 组 中 ,数据 插入 操作 速 
度 较 慢 。 

ip2 ”这 人 句 话 的 含义 是 : 链接 表 并 不 能 解决 所 有 的 数据 存储 问题 ,但 是 它们 比 其 他 一 些 和 常见 结构 ， 
如 树 的 功能 更 强 ,概念 上 也 更 简单 。 

ip3 这 人 句 话 的 含义 是 : 由 于 在 一 个 表 里 有 很 多 相似 的 链接 ,因此 用 一 个 分 开 的 类 区 别 它 们 很 有 
必要 。 

注 4 这 人 句 话 的 含义 是 : 这 种 类 的 定义 有 时 称 为 目 引 用 ,因为 它 包 含 一 个 它 目 己 的 类 定义 。 

注 5 No matter how 为 状语 从 名 ;insertion and searching (and sometimes deletion) 为 句子 的 主语 ;can 
take close to 为 谓语 。 这 人 句 话 的 含义 是 : 不 管 有 多 少 个 数据 项 ,插入 及 查找 所 花 时 间 差 不 多 , 即 
0O(1) 的 时 间 级 。 

ibo 这 人 句 话 的 含义 是 : 对 于 一 些 类 型 的 哈 希 表 , 当 表 较 满 的 时 候 , 执 行 的 效率 将 大 大 降级 ,因此 程 
序 员 必须 清楚 地 知晓 有 多 少数 据 项 将 被 保存 (或 将 数据 阶段 性 地 传输 到 大 的 哈 希 表 , 这 比较 消耗 时 间 ) 。 

注 7 这 人 句 话 的 含义 是 : 然后 ,如 果 你 不 需要 有 序 地 访问 数据 项 ,也 可 以 预先 预计 数据 库 的 大 小 , 那 
么 哈 布 表 可 能 在 速度 和 效率 方面 不 匹配 。 


Associated Reading 


Lists 


The array implementation of our collection has one serious drawback: you must know 
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the maximum number of items in your collection when you create it. This presents problems 
in programs in which this maximum number cannot be predicted accurately when the program 


starts up. Fortunately, we can use a structure called a linked list to overcome this limitation. 
1. Circularly linked lists 


By ensuring that the tail of the list is always pointing to the head, we can build a 


circularly linked list. *' 


If the external pointer ( the one in struct t _ node in our 
implementation) , points to the current "tail" of the list, then the "head" is found trivially 
via tail- » next, permitting us to have either LIFO or FIFO lists with only one external pointer 
shown as Figure 8-1. In modern processors, the few bytes of memory saved in this way 
would probably not be regarded as significant. A circularly linked list would more likely be 


used in an application which required “round-robin” scheduling or processing. ? 


node node node 


item | PT€V | next item | Prev | next item | Prev | next 
e O © © © 


Figure 8-1  Circularly linked lists 


Doubly linked lists have a pointer to the preceding item as well as one to the next. 
They permit scanning or searching of the list in both directions. ( To go backwards in a 
simple list, it is necessary to go back to the start and scan forwards. ) Many applications 


require searching backwards and forwards through sections of a list: for example, searchin 


for a common name like “Kim” in a Korean telephone directory would probably need much 
scanning backwards and forwards through a small region of the whole list, so the backward 


links become very useful. 35 In this case, the node structure is altered to have two links: 


struct t node { 

void * item; 

struct t node ** previous; 
struct t node * next; 

) node; 


2. Lists in arrays 


Although this might seem pointless ( Why impose a structure which has the overhead of 
the “next” pointers on an array?) , this is just what memory allocators do to manage 
available space. 


Memory is just an array of words. ** After a series of memory allocations and 
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deallocations, there are blocks of free memory scattered9 throughout the available heap 
space. In order to be able to re-use this memory, memory allocators will usually link freed 
blocks together in a free list by writing pointers to the next free block in the block itself. *° 
An external free list pointer points to the first block in the free list. When a new block of 
memory is requested, the allocator will generally scan the free list looking for a freed block of 
suitable size and delete it from the free list ( re-linking the free list around the deleted 
block). ** Many variations of memory allocators have been proposed: refer to a text on 
operating systems or implementation of functional languages for more details. The entry in 


the index under garbage collection will probably lead to a discussion of this topic. 


批 o 

TEL 这 人 句 话 的 含义 是 : 如 果 要 保证 一 个 表 尾 总 是 指 癌 表 头 , 须 构 建 一 个 循环 链表 。 

注 2 ”这 人 句 话 的 含义 是 : 一 个 循环 链表 将 在 这 种 情况 下 应 用 , 即 需要 时 间 片 轮转 调度 或 处 理 。 

TES 这 人 句 话 的 含义 是 : 许多 的 应 用 程序 需要 通过 列表 部 分 进行 癌 后 或 加 前 搜索 。 例 如 ,在 韩语 电 
话 海 目录 中 ,要 查找 一 个 名 为 Kim BUS Ur ,可 能 需要 通过 对 小 部 分 的 电话 短 进 行 回 前 或 加 后 扫 擂 ， 
因此 回 后 链表 就 变 得 很 有 用 了 。 

注 4 ”这 是 一 个 简单 句 , 这 人 句 话 的 含义 是 : 内 存 就 像 是 一 组 字 的 数组 。 

注 5 In order to be able to re-use this memory 作 目 的 状语 ;memory allocators 是 句子 的 主语 ;by 
writing pointers to the next free block in the block itself 是 方式 状语 。 这 人 句 话 的 含义 是 : 为 了 能 够 对 内 存 
进行 重 利 用 ,内 存 分 配 天 将 通过 指针 把 空闲 的 块 链接 起 来 。 

注 6 When a new block of memory is requested ,引导 一 个 状语 从 句 ;looking for a freed block of 
suitable size 作 伴 随 状 语 ;and delete it from the free list 与 scan 并 列 。 


Q 许多 块 
Q 分 发 
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Unit 9 Microsoft Developer Network 


Text A What is MSDN? 


The Microsoft Developer Network ( MSDN) is the portion of Microsoft responsible for 
managing the firm's relationship with developers and testers: hardware developers interested 


in the operating system (OS), developers standing on the various OS platforms9, 


developers leveraging the API and scripting languages of Microsoft's many applications. m 


The relationship management is situated in assorted9 media. web sites, newsletters, 
developer conferences, trade media, blogs and DVD distribution. The life cycle of 
the relationships ranges from legacy® support through evangelizing potential 
offerings®. 


1. History 


The service started in 1992, but initially® only the Microsoft Developer Network CD- 
ROM was available9. A Level II subscription was added in 1993, that included the 
MAPI, ODBC, TAPI and VFW SDKs. MSDN2 was opened in November 2004 as a source 
for Visual Studio 2005 API information, with noteworthy® differences being updated web 
site code, conforming® better to web standards and thus giving a long awaited improved 
support for alternative web browsers to Internet Explorer in the API browser. In 2008, the 
original MSDN cluster was retired and MSDN2 became msdn. microsoft. com. 

In 1992, Bob Gunderson began writing a column in the MSDN Developer News ( an 
actual paper-based publication) using the pseudonym®“ Dr. GUI". The column provided 


分 发 ,分 配 

遗产 

传 福音 的 潜力 产品 

最 初 地 

可 利用 的 

预定 

值得 注意 的 

遵守 ,适应 ,相似 ,一 致 ,符合 
E 3:25: 
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answers to questions submitted by MSDN subscribers®. The caricature? of Dr. GUI 
was based on a photo of Bob. When he left the MSDN team Dennis Crain took over the Dr. 
GUI role and added medical humor to the column. Upon his departure, Dr. GUI became 
the composite identity of the original group ( most notably Paul Johns) of Developer 
Technology Engineers that provided in-depth technical articles to the Library. All-in-all, it 
was a good place to from which to put all MSDN tasks in perspective®. Ken Lassesen 
produced the original system ( Panda) to publish MSDN on the Internet and in HTML instead 
of the earlier multimedia viewer engine. Dale Rogerson, Nigel Thompson and Nancy Cluts 
all published MS Press books while on the MSDN team. As of August 2010, few around 


Microsoft remember Dr. 
2. Information service 


The division9 runs an information service provided by Microsoft for software 
developers. Its main focus is on Microsoft's . NET platform, however it also features articles 
on areas such as programming practices and design patterns9. Many resources are available 
for free online, while others are available by mail via a subscription. 

Depending on subscription level, subscribers may receive early editions of Microsoft 
operating systems or other Microsoft products ( Microsoft Office applications, Visual Studio, 
etc. ). 

Universities and high schools can enroll® in the MSDN Academic Alliance program, 
which provides access to some Microsoft developer software for their computer science and 
engineering students (and possibly other students or faculty as well). An MSDNAA 
account is not an MSDN account and cannot be used to access the subscriber's section of the 
MSDN website or its downloads. 


3. Software subscriptions 


MSDN has historically offered a subscription package whereby developers have access 


提交 

捐款 人 

讽刺 
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混合 成 的 ,综合 成 的 
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分 , 除 , 部 门 

型 ,模式 ,花样 
经 由 ,通过 
订阅 者 
人 学 ,加 入 

教员 

i, , oE 


* 111。 


and licenses to use nearly all Microsoft software that has ever been released to the public. 
Subscriptions are sold on an annual basis, and cost up to $10,939 USD per year per 
subscription, as it is offered in several tiers9. Holders of such subscriptions ( except the 
lowest library-only levels) receive new Microsoft software on DVDs or via downloads every 
few weeks or months. '? The software generally comes on specially marked MSDN discs, 
but contains the identical9 retail® or volume®-license software as it is released to the 
public. 

Although in most cases the software itself functions exactly like the full product, the 
MSDN end-user license agreement prohibits9 use of the software in a business production 
environment. ® This is a legal restriction, not a technical one. As an example, MSDN 
regularly includes the latest Windows operating systems ( such as Windows Vista and 
Windows 7) , server software such as SQL Server 2008, development tools such as Visual 
Studio, and applications like Microsoft Office and MapPoint. For software that requires a 
product key, a Microsoft website generates these on demand. Such a package provides a 
single computer enthusiast with access to nearly everything Microsoft offers. However, a 
business caught with® an office full of PCs and servers running the software included in an 
MSDN subscription without the appropriate9 non-MSDN licenses for those machines would 


be treated no differently in a software licensing audit than if the software were obtained 


through piracy9. ™ 
Words 


annual adj. (形容 词 ) 年 度 的 
apporpriate adj. (形容 词 ) 适当 的 
assort vt. &vi. (动词 ) 把 ……: 分 类 
available adj. (形容 词 ) 可 利用 的 
caricature vt. & vi. (动词 ) 讽刺 


许可 证 ,执照 ,特许 

年 度 的 

相同 的 ,同一 的 

TE 

卷 , 册 ,批量 

禁止 ,不 准 

限制 ,限定 ,约束 

生成 ,产生 

热衷 者 RA 

被 抓 住 

适当 的 

非法 翻印 ,海盗 行为 ,盗版 
2. 
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cluster 
composite 
conference 
conform 
departure 
distribution 
division 
enroll 
enthusiast 
faculty 
generate 
identical 
initially 
legacy 
license 
noteworthy 
package 
pattem 
perspective 
piracy 
platform 
prohibit 
pseudonym 
restriction 
retail 
submit 
subscriber 
subscription 
tier 

via 


volume 


caught with 


n. (名 词 ) 

adj. (形容 词 ) 
n. (名 词 ) 

vt. & vi. (动词 ) 
vt. & vi. (动词 ) 
n. (名 词 ) 

n. (名 词 ) 

vt. &vi. (iA) 
n. (名 词 ) 

n. (名 词 ) 

vt. &vi. (动词 ) 
adj. (形容 词 ) 
adv. (副词 ) 

n. (名 词 ) 

n. (名 词 ) 

adj. (形容 词 ) 
n. (名 词 ) 
n. (名 词 ) 
n. (名 词 ) 
n 
n 


M 


. (名 词 ) 
. (名 词 ) 
vt. &vi. (动词 ) 
n. (名 词 ) 
n. (名 词 ) 
n. (名 词 ) 
. &vi. (动词 ) 
n. (名 词 ) 
n. (名 词 ) 
n. (名 词 ) 
vt. &vi. (动词 ) 
n. (名 词 ) 


< 
~ 
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Phrases 


evangelizing potential offerings 


Bk , 群 ,组 
混合 成 的 ,综合 成 的 
会 议 

遵守 ,适应 ,相似 一 致 ,符合 
离开 ,出 发 

分 发 ,分 配 

A^ ER ,部门 

入 学 ,加 入 ,招收 ,吸收 
教员 

生成 ,产生 
相同 的 ,同一 的 

最 初 地 

遗产 
许可 证 ,执照 ,特许 
值得 注意 的 

a, LH 3 ERR EF 
视觉 ,观点 ,远景 
非法 翻印 ,海盗 行为 
平台 

禁止 ,不 准 

假名 ;化 名 ;( 尤 指 ) 笔 名 
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服从 ,听从 

订阅 者 , 认 股 人 ;捐款 人 
预订 ,预约 ,捐款 
层 , 等 级 

经 由 ,通过 

卷 , 册 , 批 量 
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Exercises 


[Ex1] Fill in the blanks according to the text: 


Although in most cases the software itself functions exactly like the full product, the 
MSDN end-user license agreement use of the software in a business production 
environment. This is a legal , not a technical one. As an example, MSDN 
regularly includes the latest Windows operating systems ( such as Windows Vista and 
Windows 7) , server software such as SQL Server 2008, development tools such as Visual 
Studio, and applications like Microsoft Office and MapPoint. For software that requires a 
product key, a Microsoft website these on demand. Such a package provides a 
single computer with access to nearly everything Microsoft offers. However, a 
business caught with an office full of PCs and servers running the software included in an 
MSDN subscription without the non-MSDN licenses for those machines would be 
treated no differently in a software licensing audit than if the software were obtained through 


piracy. 
[Ex2] Translate into Chinese: 


(1) The Microsoft Developer Network (MSDN) is the portion of Microsoft responsible 
for managing the firm's relationship with developers and testers: hardware developers 
interested in the operating system (OS), developers standing on the various OS platforms, 
developers leveraging the API and scripting languages of Microsoft's many applications. 

(2) When he left the MSDN team Dennis Crain took over the Dr. GUI role and added 
medical humor to the column. 

(3) Component is the default implementation of IComponent and serves as the base 
class for all components in the common language runtime. 

(4) In this case, you can derive your own class from the AsyncCompletedEventArgs 
class and provide additional private instance variables and corresponding read-only public 
properties. 

(5) The System. ComponentModel namespace provides classes that are used to 
implement the run-time and design-time behavior of components and controls. 

(6) An MSDNAA account is not an MSDN account and cannot be used to access the 
subscriber's section of the MSDN website or its downloads. 

(7) All-in-all, it was a good place to from which to put all MSDN tasks in perspective. 

(8) If you add an instance of the system. AsyncCompletedEventHandler delegate to the 


event. 
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[Ex3] Choose the best answer: 


(1) In this case, you can derive your own class from the AsyncCompletedEventArgs 


class and provide private instance variables and corresponding read-only public 
properties. 
A. additional B. appropriate C. alert D. available 
(2) Many resources are available for free online, while others are available by 
mail a subscription. 
A. over B. by C. through D. via 
(3) The service started in 1992, but only the Microsoft Developer Network 
CD-ROM was available. 
A. interact B. initially C. identical D. inherits 


(4) MSDN2 was opened in November 2004 as a source for Visual Studio 2005 API 
information, with noteworthy differences being updated web site code, conforming 
better web standards and thus giving a long awaited improved support for 
alternative web browsers to Internet Explorer in the API browser. 

A. out B. up C. on D. to 

(5) This namespace includes the base classes and interfaces for attributes and 

type converters, binding to data sources, and licensing components. 


A. executing B. performing C. implementing D. enforcing 


批 注 

注 1 这 人 句 话 的 含义 是 : Microsoft 网 络 开发 平台 是 微软 的 一 部 分 ,用 于 更 好 地 处 理 开 发 和 测试 人 员 
间 的 协调 关系 , 便 件 开发 人 员 人 负责 的 是 操作 系统 (OS) ,开发 人 员 面 对 的 是 不 同 的 OS 平台 ,开发 利用 该 
API 和 微软 的 许多 应 用 程序 场 言 的 脚本 。 

注 2 这 人 句 话 的 含义 是 : 这 种 订阅 人 ( 除 最 低 水 平 外 ) 会 有 DVD ,或 通过 每 隔 数 周 或 数 月 下 载 新 的 
微软 软件 。 

注 3 Although in most cases the software itself functions exactly like the full product 引导 一 个 状语 从 
人 句 。 这 人 句 话 的 含义 是 : 虽然 在 大 多 数 情 况 下 软件 的 功能 和 完整 的 产品 完全 一 样 ,但 MSDN 的 最 终 用 户 
许可 协议 禁止 在 企业 的 生产 环境 中 使 用 软件 。 

注 4 caught with an office full of PCs and servers 为 后 置 定语 ,修饰 business, 


Text B Getting to Know MSDN 


MSDN’s primary web presence at msdn. microsoft. com is a collection of sites for the 


developer community that provide information, documentation, and discussion which is 
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authored both by Microsoft and by the community at large. Recent emphasis9 on and 
incorporation of® applications such as forums®, blogs, library annotations, and social 
bookmarking are changing the nature of the MSDN site from a one-way information service to 
an open dialog between Microsoft and the developer community. The main website and most 


of its constituent applications below are available in 56 or more languages. 
1. System. ComponentModel namespace 


The System. ComponentModel namespace provides classes that are used to implement 
the run-time and design-time behavior of components and controls. *' This namespace 
includes the base classes and interfaces for implementing? attributes and type converters, 
binding to data sources, and licensing components. 
The classes in this namespace divide into the following categories. 
* Core component classes. See the Component, IComponent, Container, and 
IContainer classes9. 

e Component licensing. See the License, LicenseManager, LicenseProvider, and 
LicenseProviderAttribute classes. 

e Attributes. See the Attribute class. 

e Descriptors and persistence. See the TypeDescriptor, EventDescriptor, and 
PropertyDescriptor classes. 


* Type converters. See the TypeConverter class. 
2. AsyncCompletedEventArgs class 


It provides data for the MethodNameCompleted event. 


If you are using a class that implements the Event-based A synchronous Pattern 


Overview , the class will provide a MethodNameCompleted event. STE you add an instance of 
the System. ComponentModel. AsyncCompletedEventHandler delegate to the event, you will 


receive information about the outcome of a synchronous operations in the 
AsyncCompletedEventArgs parameter of the corresponding® event-handler method. 


The client application’s event-handler delegate can check the Cancelled property to 
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determine if the asynchronous task was cancelled. ? 

The client application's event-handler delegate can check the Error property to determine 
if an exception occurred during execution of the asynchronous task®. 

If the class supports multiple asynchronous methods, or multiple calls to the same 
asynchronous method, you can determine which task raised the MethodNameCompleted event 
by checking the value of the UserState property. 7? Your code will need to track these tokens ， 
known as task IDs, as their corresponding asynchronous tasks start and complete. 

Classes that follow the Event-based Asynchronous Pattern can raise events to alert 
clients about the status of pending asynchronous operations. If the class provides a 
MethodNameCompleted event, you can use the AsyncCompletedEventArgs to tell clients 
about the outcome of asynchronous operations. 

You may want to communicate to clients more information about the outcome of an 
asynchronous operation than an AsyncCompletedEventArgs accommodates. '? In this case, 
you can derive your own class from the AsyncCompletedEventArgs class and provide 
additional® private instance variables and corresponding read-only public properties. 
Call the RaiseExceptionIfNecessary method before returning the property value, in case the 


operation was canceled or an error occurred. 
3. IComponent interface 


Provides functionality required by all components. 

Component is the default implementation of IComponent and serves as the base class for 
all components in the common language runtime. 

You can contain components in a container. In this context 9, containment refers to 
logical containment, not visual containment. 56 You can use components and containers in a 
variety of9 scenarios9 , both visual and non visual. 

System. Windows. Forms. Control inherits® from Component, the default 


implementation of IComponent. '* 


例外 
异步 任务 执行 过 程 中 
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A component interacts. with its container primarily through a container-provided 
ISite, which is a repository® of container-specific per-component information. 

To be a component, a class must implement the IComponent interface and provide a 
basic constructor that requires no parameters or a single parameter of type IContainer. For 


more information about implementing IComponent, see Programming with Components. 


Words 

additional adj. (和 形容词 ) 添加 的 ,额外 的 
alert adj. (形容 词 ) 警觉 的 
category n. (名 词 ) 种 类 ,类 别 
Component, IComponent, n. ( 专 有 名 词 ) 组 件 类 ,组件 接口 类 ,容器 
Container, and IContainer classes 类 ,容器 接口 类 
constituent n. (474) 选民 ,成 分 ,组 分 
corresponding adj. (形容 词 ) 相应 的 ,相当 的 
documentation n. (名 词 ) 文件 
emphasis n. (名 词 ) 强调 ,重兵 
exception n. (名 词 ) 例外 
forums n. (名 词 ) 论坛 
Implement vt. &vi. (动词 ) 使 生效 ,履行 ,实施 
inherit vt. & vi. (Mia) 继承 
instance n. (名 词 ) 实例 ,实体 
interact vt. & vi. (动词 ) 相互 作用 ,相互 影响 
parameter n. (名 词 ) 界限 ,范围 ,参数 
pending prep. (介词 ) 直到 ,等 到 ……: 期 间 
persistence n. (名 词 ) 坚持 
repository n. (名 词 ) 储藏 室 ,仓库 
scenarios n. (名 词 ) 情景 
synchronous adj. (形容 词 ) 同时 发 生 的 ,同步 的 
visual adj. (形容 词 ) 视觉 的 ,看 得 见 的 

Phrases 
incorporation of 纳入 
in case 万 一 ;假使 


© ”相互 作用 ,相互 影响 
图 ”储藏 室 , 仓 库 
O 界限 ,范围 ,参数 
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in a variety of 在 不 同 的 


He 注 

ibl 这 人 句 话 的 含义 是 : System. ComponentModel 命名 空间 提供 了 一 些 用 于 实现 运行 时 和 设计 时 
组 件 和 控件 的 行为 类 。 

ip2 这 人 句 话 的 含义 是 : 如 果 您 使 用 的 类 实现 了 基于 事件 的 同步 模式 概述 ,该 类 将 提供 一 个 
MethodNameCompleted 事件 。 

ip3 这 人 句 话 的 含义 是 : 客户 靖 应 用 程序 的 事件 处 理 程序 委托 可 以 检查 Cancelled 属性 ,以 确定 是 
否 异 步 任务 被 取消 。 

注 4 这 人 句 话 的 含义 是 : 如 果 类 支持 多 个 异步 方法 ,或 多 次 调用 同一 个 异步 方法 ,你 可 以 通过 检查 
UserState 属性 决定 哪 一 个 任务 触发 MethodNameCompleted 事件 。 

注 5 这 句 话 的 含义 是 : 你 可 能 想 传 达 给 客户 更 多 的 异步 操作 结果 , 而 不 只 是 
AsyncCompletedEventArgs 资料 。 

ipo 这 人 句 话 的 含义 是 : 在 这 种 情况 下 , 容 天 是 指 逻 辑 上 的 ,而 不 是 可 视 化 容 需 。 

注 7 这 人 句 话 的 含义 是 : System. Windows. Forms. Control 从 Component 中 继承 , 默认 是 
IComponent , 


Associated Reading 


Types of Bitmaps 


A bitmap is an array of bits that specifies the color of each pixel in a rectangular array of 
pixels. The number of bits devoted to an individual pixel determines the number of colors 
( Table 9-1) that can be assigned to that pixel shown as Figure 9-1. For example, if each 
pixel is represented by 4 bits, then a given pixel can be assigned one of 16 different colors 
(2' 216). The following table shows a few examples of the number of colors that can be 


assigned to a pixel represented by a given number of bits. 


Table 9-1 Number of color 


Bits per pixel Number of colors that can be assigned to a pixel 
1 2 =2 
2 2? =4 
4 2* =16 
8 2° 2256 
16 2" 265 536 
24 2^" =16 777 216 


Disk files that store bitmaps usually contain one or more information blocks that store 
information such as number of bits per pixel, number of pixels in each row, and number of 
rows in the array. Such a file might also contain a color table ( sometimes called a color 
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palette). A color table maps numbers in the bitmap to specific colors. The following 
illustration shows an enlarged image along with its bitmap and color table. Each pixel is 
represented by a 4-bit number, so there are 2* =16 colors in the color table. Each color in the 
table is represented by a 24-bit number; 8 bits for red, 8 bits for green, and 8 bits for blue. 
The numbers are shown in hexadecimal (base 16) form; A=10, B=11, C=12, D=13, E= 
14, F=15. 

Look at the pixel in row 3, column 5 of the image shown as Figure 9-1. The 
corresponding number in the bitmap is 1. The color table tells us that 1 represents the color 
red, so the pixel is red. All the entries in the top row of the bitmap are 3. The color table 
tells us that 3 represents blue, so all the pixels in the top row of the image are blue. 

Note Some bitmaps are stored in bottom-up format; the numbers in the first row of the 


bitmap correspond to the pixels in the bottom row of the image. 


000000 
FF0000 
OOFFOO 
0000FF 
EPPEPP 
FFFF00 
FFOOFF 
OOFFFF 
FF0080 
FF8040 
804000 
008080 
800000 
800080 
8080FF 


l2] cc c ccu 
l2 上 一 上 一 
Noe fn ff UO 
NY kK nun 上 一 
Noe A U Uv ff WwW 
NY kK OU = W 
NY 一 上 上 mm 一 上 WwW 
l2 co ccc cU 
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Figure 9-1] A bitmap using color talbe stored color 


A bitmap that stores indexes into a color table is called a palette-indexed bitmap ( 索 
5|). Some bitmaps have no need for a color table shown as Figure 9-2. For example, if a 
bitmap uses 24 bits per pixel, that bitmap can store the colors themselves rather than indexes 
into a color table. The following illustration shows a bitmap that stores colors directly (24 
bits per pixel) rather than using a color table. The illustration also shows an enlarged view of 
In the bitmap, FFFFFF represents white, FF0000 represents red, 
and 0000FF represents blue. 


the corresponding image. 


QOFFOO represents green, 
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0000FF 
00FF00 
OOFFOO 
OOFFOO 
OOFFOO 
00FF00 
00FF00 
0000FF 


0000FF 
FF0000 
FFFFFF 
FF0000 
FFFFFF 
FF0000 
FFFFFF 
0000FF 


0000FF 
FFFFFF 
FF0000 
FFFFFF 
FF0000 
FFFFFF 
FF0000 
0000FF 


0000FF 
FF0000 
FFFFFF 
FF0000 
FFFFFF 
FF0000 
FFFFFF 
0000FF 


0000FF 
FFFFFF 
FF0000 
FFFFFF 
FF0000 
FFFFFF 
FF0000 
0000FF 


0000FF 
FF0000 
FFFFFF 
FF0000 
FFFFFF 
FF0000 
FFFFFF 
0000FF 


0000FF 
FFFFFF 
FF0000 
FFFFFF 
FF0000 
FFFFFF 
FF0000 
0000FF 


0000FF 
00FF00 
OOFFOO 
OOFFOO 
OOFFOO 
00FF00 
O00FF00 
0000FF 


Figure 9-2 A bitmap's directly stored colors 


Unit 10 Compilers Principles 


Text A The Science of Code Optimization 


The term * optimization9" in compiler design refers to the attempts that a compiler 
makes to produce code that is more efficient than the obvious code. “Optimization” is 


thus a misnomer®, since there is no way that the code produced by a compiler can be 


guaranteed to be as fast or faster than any other code that performs the same task. tel 


In modern times, the optimization of code that a compiler performs has become both 
more important and more complex9. '? It is more complex because processor architectures 


have become more complex, yielding more opportunities to improve the way code 
executes9. It is more important because massively parallel computers require substantial 
optimization, or their performance suffers by orders of magnitude. With the likely 
prevalence of multi-core® machines (computers with chips that have large numbers of 
processors on them) , all compilers will have to face the problem of taking advantage of ® 
multiprocessor machines. 

It is hard, if not impossible, to build a robust compiler out of "hacks. " Thus, an 
extensive and useful theory has been built up around the problem of optimizing code. The use 
of a rigorous mathematical foundation allows us to show that an optimization is correct 
and that it produces the desirable effect for all possible inputs. We shall see, starting in 


Chapter 9, how models such as graphs, matrices, and linear programs are necessary if 


最 佳 化 ;最 优化 

自动 编码 器 ;编译 器 
有 效 的 

误 称 ;用 词 不 当 
保证 ;担保 
复杂 的 ;合成 物 
易 受 影响 的 

执行 ,完成 
平行 的 
大 小 , 量 级 

多 芯 的 ;多 核 的 
使 用 ,利用 
数学 上 的 ,精确 的 
模型 ,矩阵 

线 状 的 
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the compiler is to produce well optimized code. 

On the other hand, pure theory alone is insufficient. Like many real-world 
problems, there are no perfect answers. In fact, most of the questions that we ask in compiler 
optimization are un-decidable. One of the most important skills in compiler design is the 
ability to formulate the right problem to solve. We need a good understanding of the 
behavior of programs to start with and thorough experimentation and evaluation to validate 
our intuitions. Compiler optimizations must meet the following design objectives: 

The optimization must be correct, that is, preserve the meaning of the compiled 
program; 

The optimization must improve the performance of many programs ; 

The compilation time must be kept reasonable; 

The engineering effort required must be manageable. 

It is impossible to overemphasize9 the importance of correctness. It is trivial to write 
a compiler that generates fast code if the generated code need not be correct! Optimizing 
compilers are so difficult to get right that we dare say that no optimizing compiler is 
completely error-free! Thus, the most important objective in writing a compiler is that it is 
correct. '? 

The second goal is that the compiler must be effective in improving the performance of 
many input programs. Normally, performance means the speed of the program execution. 
Especially in embedded applications, we may also wish to minimize9 the size of the 
generated code. And in the case of mobile devices, it is also desirable that the code 
minimizes power consumption. Typically, the same optimizations that speed up execution 
time also conserve power. Besides performance, usability aspects such as error reporting and 
debugging are also important. 

Third, we need to keep the compilation time short to support a rapid development 
and debugging cycle. This requirement has become easier to meet as machines get faster. 
Often, a program is first developed and debugged without program optimizations. Not only is 
the compilation time reduced, but more importantly, un-optimized programs are easier to 
debug, because the optimizations introduced by a compiler often obscure the relationship 
between the source code and the object code. ** Turning on optimizations in the compiler 


sometimes exposes new problems in the source program9; thus testing must again be 


不 够 的 ;不 足 的 
把 …… 用 公式 表示 


过 分 强调 
使 减 到 最 少 
编译 ;编辑 物 
在 源 程序 中 
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performed on the optimized code. The need for additional testing sometimes deters the use of 
optimizations in applications, especially if their performance is not critical. 

Finally, a compiler is a complex system; we must keep the system simple to assure that 
the engineering and maintenance costs of the compiler are manageable. There is an infinite 
number of program optimizations that we could implement, and it takes a nontrivial® 
amount of effort to create a correct and effective optimization. ^ We must prioritize® the 
optimizations, implementing only those that lead to the greatest benefits on source programs 


encountered in practice. 


Thus, in studying compilers, we learn not only how to build a compiler, but also the 


general methodology of solving complex and open-ended problems. © The approach used in 
compiler development involves both theory and experimentation. We normally start by 


formulating the problem based on our intuitions® on what the important issues are. 


Words 

compilation n. (474) 编译 
compiler n. (名 词 ) 目 动 编码 器 ;编辑 人 
complex adj. (形容 词 ) 复杂 的 ;合成 物 
efficient adj. (形容 词 ) 有 效 的 
execute vt. & vi. (动词 ) 执行 ,完成 
formulate vt. & vi. (动词 ) iE 用 公式 表示 ;制定 
guarantee n. (名词) 保证 ;担保 
infinite adj. (形容 词 ) 无 限 的 ,无 穷 的 
insufficient adj. (形容 词 ) 不 够 的 ,不 足 的 
linear adj. (形容 词 ) 线 状 的 
magnitude n. (名 词 ) 大 小 , 量 级 
mathematical adj. (形容 词 ) 数学 上 的 ,精确 的 
matrix n. (名 词 ) 模型 ,矩阵 
minimize vt. &vi. (动词 ) 使 减 到 最 少 
misnomer n. (名 词 ) 误 称 ;用 词 不 当 
multicore adj. (形容 词 ) 多 芯 的 ;多 核 的 
nontrivial adj. (形容 词 ) 非 平 凡 的 
optimization n. (名 词 ) 最 佳 化 ,最 优化 

D 无 限 的 ,无 穷 的 
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overemphasize vt. & vi. (动词 ) 过 分 强调 


paralle adj. (形容 词 ) 平行 的 
prevalence n. (名 词 ) 流行 ,普遍 
validate vt. (动词 ) 证 实 
yielding adj. (形容 词 ) 易 受 影响 的 
Phrases 

in the source program 在 源 程序 
on our intuitions ^ 3X, 111 B] EL K 
taking advantage of 利用 

Exercises 


[Ex1] Fill in the blanks according to the text: 


In modern times, the optimization of code that a compiler performs has become both 
more important and more . It is more complex because processor architectures have 
become more complex, more opportunities to improve the way code . It 
is more important because massively computers require substantial optimization, or 
their performance suffers by orders of- . With the likely prevalence of multi-core 
machines ( computers with chips that have large numbers of processors on them), all 


compilers will have to face the problem of taking advantage of multiprocessor machines. 
[Ex2] Translate into Chinese: 


(1) The term "optimization" in compiler design refers to the attempts that a compiler 
makes to produce code that is more efficient than the obvious code. 

(2) In modern times, the optimization of code that a compiler performs has become 
both more important and more complex. 

(3) In fact, most of the questions that we ask in compiler optimization are undecidable. 

(4) We need a good understanding of the behavior of programs to start with and 
thorough experimentation and evaluation to validate our intuitions. 

(5) The optimization must be correct, that is, preserve the meaning of the compiled 
program. 

(6) The optimization must improve the performance of many programs. 

(7) The compilation time must be kept reasonable. 

(8) It is trivial to write a compiler that generates fast code if the generated code need 
not be correct ! 
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[Ex3] Choose the best answer: 


(1) In modern times, the optimization of code a compiler performs has 
become both more important and more complex. 
A. that B. who C. what D. where 
(2) It is impossible to the importance of correctness. 
A. overemphasize B. overemphasizing C. overestimation — D. overestimate 
(3) The second goal is that the compiler be effective in improving the 
performance of many input programs. 
A. should B. must C. ought D. can 
(4) We need to keep the compilation time short to support a rapid 


development and cycle. 
A. debug B. debugged C. debugging D. debugs 
(5) In studying compilers, we learn not only how to build a compiler, but also the 
general methodology of complex and problems. 
A. solving , open-ended B. solved , open-ended 
C. solving , open-ending D. solved , open-ending 


批 注 

注 1 Optimization 为 主语 (优化 ) ;thus a misnomer 7j xi ; since- 7| SJ ES] A ^3] ; that--- 修饰 no 
way ;the code produced by a complier X MAJ EH, 

{£2 That a compiler performs 从 人 句 修 饰 主语 the optimization of code; 

Has 为 谓语 ;become…complex 为 宾语 。 

注 3 Optimizing compilers 为 主语 ;are 是 谓语 ;so…that 引导 状语 从 语 ;no optimizing compiler 是 从 
句 主语 ;is 是 从 句 谓 语 。 

注 4 主语 : compiler; 谓 语 : hides; distributing the computation 分 词 引导 独立 结构 ,与 because 引导 
的 状语 从 名 并 列 。 这 人 句 话 的 含义 是 : 这 不 只 缩短 了 编译 时 间 ,而 且 更 重要 的 是 ,因为 由 编译 顺 引 入 的 优 
化 通常 使 源 代码 与 目标 代码 之 间 的 关系 变 得 模糊 ,所 以 未 经 优化 的 程序 更 容易 调试 。 

TES 这 人 句 话 的 含义 是 : 我 们 可 以 进行 无 限 多 的 程序 优化 ,而 且 创 造 一 个 正确 有 效 的 优化 需要 很 多 
的 努力 。 

ike 这 句 话 的 含义 是 : 因此 ,研究 编译 器 时 ,我 们 不 仅 要 学 习 如 何 建立 一 个 编译 器 ,还 要 学 习 解 决 
复业 和 开放 式 问 题 的 一 般 方 法 。 


Text B Optimizations for Computer Architectures 


The rapid evolution® of computer architectures has also led to an insatiable® demand 
for new compiler technology . Almost all high-performance systems take advantage of the 


@ 发 展 
© 无 法 满足 的 
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same two basic techniques: parallelism9 and memory hierarchies9. Parallelism can be 
found at several levels; at the instruction level, where multiple operations are executed 
simultaneously and at the processor level, where different threads of the same application 
are run on different processors. Memory hierarchies are a response to the basic limitation 
that we can build very fast storage or very large storage, but not storage that is both fast 
and large. 

All modern microprocessors exploit instruction-level parallelism. However, this 
parallelism can be hidden from the programmer. Programs are written as if all instructions 
were executed in sequence; the hardware dynamically® checks for dependencies in the 
sequential instruction stream and issues them in parallel when possible. In some cases, the 
machine includes a hardware scheduler that can change the instruction ordering to increase 
the parallelism in the program. Whether the hardware reorders the instructions or not, 
compilers can rearrange® the instructions to make instruction-level parallelism more 
effective. 

Instruction-level parallelism can also appear explicitly® in the instruction set. VLIW 
( Very Long Instruction Word) machines have instructions that can issue multiple operations 
in parallel. The Intel IA64 is a well-known example of such architecture. All high- 
performance, general-purpose microprocessors also include instructions that can operate on a 
vector of data at the same time. Compiler techniques have been developed to generate 
code automatically for such machines from sequential programs. 

Multiprocessors have also become prevalent; even personal computers often have 
multiple processors. Programmers can write multithreaded€ code for multiprocessors, or 
parallel code can be automatically generated by a compiler from conventional sequential 


programs. Such a compiler hides from the programmers the details of finding parallelism in a 


平行 

分 级 

多 样 的 ;复合 的 
同时 发 生地 
限制 

存储 

利用 

顺序 ,程式 
动态 地 
调度 程序 
重新 排列 
明确 地 
生成 
自动 地 

多 线程 的 
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program, distributing the computation across the machine, and minimizing 
synchronization® and communication among the processors. ® Many scientific-computing 
and engineering applications are computation-intensive and can benefit greatly from parallel 
processing. Parallelization techniques have been developed to translate automatically 
sequential scientific programs into multiprocessor code. 

A memory hierarchy consists of® several levels of storage with different speeds and 
sizes, with the level closest to the processor being the fastest but smallest. The average 
memory-access time of a program is reduced if most of its accesses are satisfied by the faster 
levels of the hierarchy. Both parallelism and the existence of a memory hierarchy improve the 
potential performance of a machine, but they must be harnessed® effectively by the 
compiler to deliver real performance on an application. 

Memory hierarchies are found in all machines. A processor usually has a small number 
of registers consisting of hundreds of9 bytes, several levels of caches containing 
kilobytes® to megabytes, physical memory containing megabytes to gigabytes, and finally 
secondary storage that contains gigabytes® and beyond. Correspondingly, the speed of 
accesses between adjacent® levels of the hierarchy® can differ by two or three orders of 
magnitude. The performance of a system is often limited not by the speed of the processor 
but by the performance of the memory subsystem. 2 While compilers traditionally focus on 
optimizing the processor execution, more emphasis® is now placed on making the memory 
hierarchy more effective. 

Using registers effectively is probably the single most important problem in optimizing a 
program. Unlike registers that have to be managed explicitly in software, caches and physical 
memories are hidden from the instruction set and are managed by hardware. It has been found 
that cache-management policies implemented by hardware are not effective in some cases, 
especially in scientific code that has large data structures ( arrays, typically). It is possible to 
improve the effectiveness of the memory hierarchy by changing the layout of the data, or 


changing the order of instructions accessing the data. We can also change the layout of code 


to improve the effectiveness of instruction caches'?. 
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automatically 
dynamically 
emphasis 
evolution 
explicitly 
exploit 
generate 
gigabytes 
harnessed 
hierarchy 
insatiable 
kilobyte 
limitation 
multiple 
multithreaded 
parallelism 
rearrange 
scheduler 
sequence 
simultaneously 
storage 


synchronization 


consists of 
hundreds of 


批 it 


Words 


adv. (副词 ) 
adv. (副词 ) 

vt. & vi. (动词 ) 
n. (名 词 ) 

adv. (副词 ) 

vt. & vi. (动词 ) 
vt. & vi. (动词 ) 
n. (名 词 ) 

vt. (动词 ) 

n. (名 词 ) 

adj. (形容 词 ) 
n. (名 词 ) 

n. (名 词 ) 

adj. (形容 词 ) 
adj. (形容 词 ) 
n. (名 词 ) 

vt. (动词 ) 

n. (名 词 ) 

n. (名 词 ) 

adv. (副词 ) 

n. (名 词 ) 

n. (名 词 ) 


Phrases 


由 什么 组 成 
数 以 百 计 的 


自动 地 
动态 地 ;充满 活力 地 ;不 断 变 化 地 
强调 

发 展 
明确 地 
利用 

生成 ,产生 
千 兆 字 市 
治理 

分 级 
无 法 满足 的 
千 字 市 
限制 

多 样 的 ;复合 的 
多 线程 的 
平行 
重新 排列 
调度 程序 
顺序 ,程式 
同时 发 生地 
存储 
同时 性 


注 1 Such a compiler 为 句子 的 主语 ,finding parallelism in a program, distributing the computation 


across the machine, and minimizing synchronization and communication among the processors 7JJf-7 Z5 FJ . 
这 人 句 话 的 含义 是 : 这 种 编译 项 对 程序 员 隐 藏 了 在 程序 中 找到 并 行 结构 的 细节 ERSTES A B TED ie PF 
最 大 限度 地 减少 处 理 天 之 间 的 同步 和 通信 。 

注 2 这 人 句 话 的 含义 是 : 一 个 系统 的 性 能 往往 不 是 被 处 理 久 的 速度 限制 ,而 是 被 记忆 子 系统 的 性 能 


限制 。 
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ik3 我 们 可 以 通过 改变 数据 的 布局 或 者 改变 访问 数据 的 指令 的 顺序 改善 内 存 层次 结构 的 有 效 
VE ,也 可 以 通过 改变 代码 布局 改善 指令 高 速 缓存 的 有 效 性 。 


Associated Reading 


Introducing “TINY” 


In the last installment, I showed you the general idea for the top-down development of a 
compiler. I gave you the first few steps of the process for compilers for Pascal and C, but I 
stopped far short of pushing it through to completion. The reason was simple; if we’re going 
to produce a real, functional compiler for any language, I'd rather do it for KISS, the 
language that I’ve been defining in this tutorial series. 

In this installment, we're going to do just that, for a subset of KISS which I've chosen 
to call TINY. 

The process will be essentially that outlined in Installment IX , except for one notable 
difference. In that installment, I suggested that you begin with a full BNF description of the 
language. That's fine for something like Pascal or C, for which the language definition is 
firm. In the case of TINY, however, we don't yet have a full description, we seem to be 
defining the language as we go. That's OK. In fact, it's preferable, since we can tailor the 
language slightly as we go, to keep the parsing easy. So in the development that follows, 
we'll actually be doing a top-down development of BOTH the language and its compiler. The 
BNF description will grow along with the compiler. 

In this process, there will be a number of decisions to be made, each of which will 
influence the BNF and therefore the nature of the language. At each decision point I'll try to 
remember to explain the decision and the rationale behind my choice. That way, if you 
happen to hold a different opinion and would prefer a different option, you can choose it 
instead. You now have the background to do that. I guess the important thing to note is that 
nothing we do here is cast in concrete. When YOU RE designing YOUR language, you 
should feel free to do it YOUR way. 

Many of you may be asking at this point; Why bother starting over from scratch? We 
had a working subset of KISS as the outcome of Installment VÍ (lexical scanning). Why not 
just extend it as needed? The answer is threefold. First of all, I have been making a number 
of changes to further simplify the program ... changes like encapsulating the code generation 
procedures, so that we can convert to a different target machine more easily. Second, I want 
you to see how the development can indeed be done from the top down as outlined in the last 
installment. Finally, we both need the practice. Each time I go through this exercise, I get a 
little better at it, and you will, also. 

Many years ago there were languages called Tiny BASIC, Tiny Pascal, and Tiny C, 
each of which was a subset of its parent full language. Tiny BASIC, for example, had only 
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single-character variable names and global variables. It supported only a single data type. 
Sound familiar? At this point we have almost all the tools we need to build a compiler like 
that. Yet a language called Tiny-anything still carries some baggage inherited from its parent 
language. I’ve often wondered if this is a good idea. Granted, a language based upon some 
parent language will have the advantage of familiarity, but there may also be some peculiar 
syntax carried over from the parent that may tend to add unnecessary complexity to the 
compiler. ( Nowhere is this truer than in Small C. ) 

Ive wondered just how small and simple a compiler could be made and still be useful, if 
it were designed from the outset to be both easy to use and to parse. Let's find out. This 
language will just be called " TINY," period. Its a subset of KISS, which I also haven't 
fully defined, so that at least makes us consistent ( !). I suppose you could call it TINY 
KISS. But that opens up a whole can of worms involving cuter and cuter ( and perhaps more 
risqué) names, so let's just stick with TINY. The main limitations of TINY will be because 
of the things we haven't yet covered, such as data types. Like its cousins Tiny C and Tiny 
BASIC, TINY will have only one data type, the 16-bit integer. The first version we develop 
will also have no procedure calls and will use single-character variable names, although as 
you will see we can remove these restrictions without much effort. 

The language I have in mind will share some of the good features of Pascal, C, and 
Ada. Taking a lesson from the comparison of the Pascal and C compilers in the previous 
installment, though, TINY will have a decided Pascal flavor. Wherever feasible, a language 
structure will be bracketed by keywords or symbols, so that the parser will know where it's 
going without having to guess. 

One other ground rule; As we go, Pd like to keep the compiler producing real, 
executable code. Even though it may not DO much at the beginning, it will at least do it 
correctly. 

Finally, Tll use a couple of Pascal restrictions that make sense; All data and procedures 
must be declared before they are used. That makes good sense, even though for now the only 
data type we'll use is a word. This rule in turn means that the only reasonable place to put the 
executable code for the main program is at the end of the listing. 


The top-level definition will be similar to Pascal: 
< progran» ::= PROGRAM < tœ level decl» «mein» '.' 


Already, we've reached a decision point. My first thought was to make the main block 
optional. It doesn't seem to make sense to write a "program" with no main program, but it 
does make sense if we're allowing for multiple modules, linked together. As a matter of fact, 
I intend to allow for this in KISS. But then we begin to open up a can of worms that I'd 
rather leave closed for now. For example, the term " PROGRAM " really becomes a 
misnomer. 
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The MODULE of Modula-2 or the Unit of Turbo Pascal would be more appropriate. 
Second, what about scope rules? We'd need a convention for dealing with name visibility 
across modules. Better for now to just keep it simple and ignore the idea altogether. 

There's also a decision in choosing to require the main program to be last. I toyed with 
the idea of making its position optional, as in C. The nature of SK * DOS, the OS I’m 
compiling for, make this very easy to do. But this doesn't really make much sense in view of 
the Pascal-like requirement that all data and procedures be declared before they're referenced. 
Since the main program can only call procedures that have already been declared, the only 
position that makes sense is at the end, a Pascal. 


Given the BNF above, let's write a parser that just recognizes the brackets: 


{ Parse and Translate a Program } 
procedure Prog; 
begin 

Match ("p"); 

Header; 

Prolog; 

Match("."); 

Epilog; 


The procedures Prolog and Epilog emit the code for identifying the main program, and 


for returning to the OS: 


{ Write the Prolog } 
procedure Prolog; 


begin 
PostLabel ("MAIN") ; 
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{ Write the Epilog ] 


procedure Epilog; 

begin 
FmitIn ("DC WARMST") ; 
Emitin ("END MAIN!) ; 


At this point, TINY will accept only one input “program,” the null program: 
PROGRAM . (or 'p.' in our shorthand.) 


Note, though, that the compiler DOES generate correct code for this program. It will 
run, and do what you'd expect the null program to do, that is, nothing but return gracefully 
to the OS. 

As a matter of interest, one of my favorite compiler benchmarks is to compile, link, and 
execute the null program in whatever language is involved. You can learn a lot about the 
implementation by measuring the overhead in time required to compile what should be a 
trivial case. It's also interesting to measure the amount of code produced. In many 
compilers, the code can be fairly large, because they always include the whole run-time 
library whether they need it or not. Early versions of Turbo Pascal produced a 12K object file 
for this case. VAX C generates 50K! 

The smallest null programs I’ve seen are those produced by Modula-2 compilers, and 
they run about 200-800 bytes. 

In the case of TINY, we HAVE no run-time library as yet, so the object code is indeed 
tiny: two bytes. That's got to be a record, and it’s likely to remain one since it is the 
minimum size required by the OS. 

The next step is to process the code for the main program. Pll use the Pascal BEGIN- 
block: 


<main> ::= <block> END 
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Here, again, we have made a decision. We could have chosen to require a 
"PROCEDURE MAIN” sort of declaration, similar to C. I must admit that this is not a bad 
idea at all ... I don't particularly like the Pascal approach since I tend to have trouble locating 
the main program in a Pascal listing. But the alternative is a little awkward, too, since you 
have to deal with the error condition where the user omits the main program or misspells its 
name. Here I’m taking the easy way out. 

Another solution to the “where is the main program" problem might be to require a 


name for the program, and then bracket the main by 


BEGIN < name > 


END < name > 


Similar to the convention of Modula 2. This adds a bit of “ syntactic sugar” to the 
language. Things like this are easy to add or change to your liking, if the language is your 
own design. 


To parse this definition of a main block, change procedure Prog to read; 


{ Parse and Translate a Program } 


prooedure Prog; 
begin 

Match ("p'); 

Header; 

Main; 

Match (".'); 
end; 
ee } 
and add the new procedure 


{ Parse and Translate a Main Program } 


procedure Main; 
begin 
Match ("b'); 
Prolog; 
Match ('e'); 
Epilog; 


Now, the only legal program is: 


PROGRAM FEGIN END . (or 'rbe.") 
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Aren't we making progress??? Well, as usual it gets better. You might try some 
deliberate errors here, like omitting the ‘b’ or the ‘e’, and see what happens. As always, 
the compiler should flag all illegal inputs. 

DECLARATIONS 

The obvious next step is to decide what we mean by a declaration. My intent here is to 
have two kinds of declarations; variables and procedures/functions. At the top level, only 
global declarations are allowed, just as in C. 

For now, there can only be variable declarations, identified by the keyword VAR 
( abbreviated ‘v’ ): 


< tœ level decls> ::= ( «datadeclaration» ) 
< data declaration» ::= VAR < var-list ^ 


Note that since there is only one variable type, there is no need to declare the type. 
Later on, for full KISS, we can easily add a type description. 


The procedure Prog becomes: 


{ Parse and Translate a Program } 


procedure Prog; 
begin 
Match ('p'); 


{ Process a Data Declaration } 


procedure Decl; 
begin 
Match ('v'); 


{ Parse and Translate Gldbal Declarations } 
procedure TopDecls; 
begin 
while Look < > 'b' œ 
case Look of 
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"v's Decl; 
else Abort ("Unrecognized Keyword ''' + Iook + '''!'); 


Note that at this point, Decl is just a stub. It generates no code, and it doesn’t process a 
list ... every variable must occur in a separate VAR statement. 

OK, now we can have any number of data declarations, each starting with a ‘v’ for 
VAR, before the BEGIN-block. Try a few cases and see what happens. 
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Unit 11 Operating System 


Text A Operating System Overview 


1. What is an operating system 


An operating system is software, consisting of programs and data that runs on computers 
and manages the computer hardware and provides common services for efficient execution of 
various application software. ™ 

For hardware functions such as input and output and memory allocation, the operating 
system acts as an intermediary9 between application programs and the computer hardware , 
although the application code is usually executed directly by the hardware, but will frequently 
call the OS or be interrupted by it. Operating systems are found on almost any device that 
contains a computer—from cellular9 phones and video game consoles to supercomputers 


and web servers. 
2. History of operating system 


In the early 1950s, a computer could execute only one program at a time. Each user had 
sole use of the computer and would arrive at a scheduled time with program and data on 
punched paper cards and tape. The program would be loaded into the machine, and the 
machine would be set to® work until the program completed or crashed. Programs could 
generally be debugged via a front panel using toggle switches and panel lights. It is 
said that Alan Turing was a master of this on the early Manchester Mark 1 machine, and he 
was already deriving the primitive conception of an operating system from the 
principles of the Universal Turing machine. i 

Later machines came with libraries of software, which would be linked to a user's 


program to assist in operations such as input and output and generating computer code from 


中 介 

蜂窝 状 的 

预定 
设置 , 设 定 
调试 

面板 
挫 牢 , 系 紧 
源 于 ;得 上 自 
原始 的 ;远古 的 
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human-readable symbolic code. This was the genesis® of the modern-day operating system. 
However, machines still ran a single job at a time. At Cambridge University in England the 
job queue was at one time a washing line from which tapes were hung with different colored 


clothes-pegs® to indicate job-priority9. 
3. Mainframes 


Through the 1950s, many major features were pioneered in the field of operating 
systems, including batch processing, input/output interrupt, buffering, multitasking , 
spooling, runtime libraries, link-loading, and programs for sorting records in files. These 
features were included or not included in application software at the option of application 
programmers, rather than in a separate operating system used by all applications. In 1959 the 
operating system was released as an integrated utility for the IBM 704, 709, and 7090 
mainframes®. 

During the 1960s, IBM’s OS/360 introduced the concept of a single OS spanning an 
entire product line was crucial® for the success of System/360. IBM’s current mainframe 
operating systems are distant descendants® of this original system and applications written 
for OS/360 can still be run on modern machines In the mid- 70s, MVS, a descendant of 


OS/360, offered the first implementation® of using RAM as a transparent cache for data. 
4. Microcomputer 


The first microcomputers did not have the capacity or need for the elaborate® operating 
systems that had been developed for mainframes and minis; minimalistic operating systems 
were developed, often loaded from ROM and known as monitors. One notable® early disk- 
based operating system was CP/M, which was supported on many early microcomputers and 
was closely imitated in MS-DOS, which became wildly popular as the operating system 
chosen for the IBM PC (IBM’s version of it was called IBM DOS or PC DOS), its 
successors® making Microsoft. %1 In the 80's Apple Computer Inc. (now Apple Inc. ) 


abandoned its popular Apple [| series of microcomputers to introduce the Apple Macintosh 
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computer with an innovative9 Graphical User Interface ( GUI) to the Mac OS. 
5. Examples of operating system 


(1) Microsoft Windows 

Microsoft Windows is a family of proprietary9 operating systems most commonly used 
on personal computers. It is the most common family of operating systems for the personal 
computer, with about 90% of the market share currently, the most widely used version of the 
Windows family is Windows XP, released on October 25, 2001. The newest version is 
Windows 7 for personal computers and Windows Server 2008 R2 for servers. 

(2) UNIX and UNIX-like operating system 

Ken Thompson wrote B, mainly based on BCPL which he used to write UNIX, based 
on his experience in the multics project. B was replaced by C, and UNIX developed into a 
large, complex family of inter-related operating systems which have been influential in every 
modern operating system. The UNIX-like family is a diverse group of operating systems, 
with several major sub-categories including System V, BSD, and GNU/Linux. The name 


“UNIX” is a trademark® of The Open Group which licenses it for use with any operating 


system that has been shown to conform to® their definitions. ? * UNIX-like" is commonly 


used to refer to the large set of operating systems which resemble® the original UNIX. 

(3) Mac OS X 

Mac OS X is a line of partially proprietary graphical operating systems developed, 
marketed, and sold by Apple Inc. , the latest of which is pre-loaded on all currently shipping 
Macintosh computers. Mac OS X is the successor to the original Mac OS, which had been 
Apple's primary operating system since 1984. Unlike its predecessor, Mac OS X is a UNIX 
operating system built on technology that had been developed at Next® through the second 
half of the 1980s and up until Apple purchased the company in early 1997. 

The operating system was first released in 1999 as Mac OS X Server 1.0, with a 
desktop-oriented version (Mac OS X v10. 0) following in March 2001. 6 Since then, six 
more distinct "client" and "server" editions of Mac OS X have been released, the most 
recent being Mac OS X v10.6, which was first made available on August 28, 2009. Releases 
of Mac OS X are named after big cats; the current version of Mac OS X is " Snow 
Leopard”. 
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(4) Other 

Older operating systems which are still used in Niche markets include OS/2 from IBM 
and Microsoft; Mac OS, the non-UNIX precursor to Apple's Mac OS X; BeOS; XTS-300. 
Some, most notably Haiku, RISC OS, MorphOS and AmigaOS 4 continue to be developed 
as minority platforms for enthusiast communities and specialist applications. Open 
VMS formerly from DEC, is still under active development by Hewlett-Packard. Yet other 
operating systems are used almost exclusively in academia, for operating systems education or 
to do research on operating system concepts. A typical example of a system that fulfills both 


roles is MINIX, while for example Singularity is used purely for research. 


Words 

cellular adj. (形容 词 ) MEA BY 
crucial adj. (形容 词 ) 重要 的 ;决定 性 的 
debug vt. & vi. (动词 ) 调试 
derive vt. &vi. (动词 ) 源 于 ;得 
descendant n. (名 词 ) la A; d 
elaborate adj. (形容 词 ) 精心 制作 的 ;详尽 的 
enthusiast n. (名 词 ) 狂热 者 ,热心 家 
genesis n. (l) 发 生 ; 起 源 
implementation n. (l) 实现 ;履行 
innovative adj. (和 形容词) 革新 的 ,创新 的 
intermediary n. (名 词 ) 中 间 人 
mainframe n. (名 词 ) 大 型 主机 
minority n. (名 词 ) 少数 民族 ;少数 派 ; 未 成 年 
notable adj. (形容 词 ) 值得 注意 的 ,显著 的 ;著名 的 
panel n. (名 词 ) 面板 
primitive adj. (形容 词 ) 原始 的 ;远古 的 
proprietary n. (名 词 ) 所 有 权 ; 所 有 人 
resemble vt. &vi. (动词 ) 类 似 , 像 
scheduled vt. &vi. (动词 ) TUE 
toggle n. (474) ERK 
trademark n. (474) 商标 

D 少数 

e 受 好 者 


。 139- 


Phrases 


clothes-pegs HR ACE BY KK 
conform to 符合 ;遵照 
job-priority 作业 优先 级 别 
set to 开始 

shown to 显示 
successors 继承 人 


批 it 

注 1 句子 主干 就 是 An operating system is software; 该 句 复 加 在 后 面 的 是 非 限 制 性 定语 从 句 ; 
consisting of programs and data 修饰 software; 而 that runs… 引 导 的 定 霹 从 句 是 修饰 programs and data, 

注 2 句子 主干 是 the operating system acts as an intermediary; Although 5| SE LE ARIE M J; It FF 
fX OS, 

iE3 It is said 引导 的 句子 是 强调 句 ;that 后 面 则 是 由 and 连接 的 两 个 简单 句 : Alan Turing was a 
master---and he was:…, 

注 4 该 句 主 干 是 One notable early disk-based operating system was CP/M; which 指 代 CP/M. 作 引 
导 非 限制 性 定语 从 名; 后 面 which became 中 的 which 指 代 MS-DOS ,引导 一 个 非 限制 性 定语 从 名。 

TES ”这 人 句 话 的 含义 是 : UNIX 这 个 名 字 是 开放 上 自由 组 织 的 商标 , 它 用 于 任何 一 个 操作 系统 ,这 个 操 
作 系 统 是 符合 它 的 定义 的 。 

ibo 这 人 句 话 的 含义 是 : 操作 系统 的 第 1 版 发 布 时 间 在 1999 年 ,名 称 是 Mac OS X Server 1.0 ,在 随 
后 的 2001 年 3 月 发 布 了 一 个 桌面 版 的 Mac OS X v10.0。 


Exercises 


[Ex1] Answer the questions according to the text: 


(1) What is an operating system? How does it work? 

(2) What features are pioneered in the field of operating system through the 1950s? 
(3) What's the difference between Mainframes and Microcomputers? 

(4) What is the Microsoft Windows? 

(5) Who wrote the UNIX? 


[Ex2] Translate into Chinese: 


(1) In the early 1950s, a computer could execute only one program at a time. 
(2) Mac OS X is a line of partially proprietary graphical operating systems developed, 
marketed, and sold by Apple Inc. 
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(3) During the 1960s, IBM's OS/360 introduced the concept of a single OS spanning 
an entire product line was crucial for the success of System/360. 

(4) Minimalistic operating systems were developed , often loaded from ROM and known 
as monitors. 

(5) The newest version is Windows 7 for personal computers and Windows Server 2008 
R2 for servers. 

(6) The UNIX-like family is a diverse group of operating systems, with several major 
sub-categories including System V, BSD, and GNU/Linux. 

(7) “UNIX-like” is commonly used to refer to the large set of operating systems which 
resemble the original UNIX. 

(8) A typical example of a system that fulfills both roles is MINIX, while for example 


Singularity is used purely for research. 
[Ex3] Choose the best answer 


(1) is a device that converts images to digital formal. 
A. Copier B. Printer C. Scanner D. Display 
(2) are those programs that help find the information you are trying to locate 
on the WWW. 
A. Windows B. Search Engines C. Web Sites D. Web Pages 
(3) An statement can perform a calculation and store the result in a variable 
so that it can be used later. 
A. executable B. input C. output D. assignment 
(4) Each program module is compiled separately and the resulting files are 


linked together to make an executable application. 


A. assembler B. source C. library D. object 
(5) is the conscious effort to make all jobs similar, roytine, and 
interchangeable. 
A. WWW B. Informatization 
C. Computerization D. Standardization 


Text B BIOS or CMOS Setup 


BIOS is the Acronym for basic input/output system, the built-in software that determines 
what a computer can do without accessing programs from a disk. On PCs, the BIOS contains 
all the code required to control the keyboard, display screen, disk drives, serial 
communications, and a number of miscellaneous functions. All these options will be shown 
as Figure 11-1 „Figure 11-2 „Figure 11-3 respectively. 
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The BIOS is typically placed in a ROM chip that comes with the computer ( it is often 
called a ROM BIOS). This ensures that the BIOS will always be available and will not be 
damaged by disk failures. It also makes it possible for a computer to boot itself. Because 
RAM is faster than ROM, though, many computer manufacturers design systems so that the 
BIOS is copied from ROM to RAM each time the computer is booted. This is known as 
shadowing. 

Because of the wide variety of computer and BIOS manufacturers over the evolution of 
computers, there are numerous ways to enter the BIOS or CMOS Setup. Below is a listing of 
the majority of these methods as well as other recommendations for entering the BIOS setup. 

Thankfully , computers that have been manufactured in the last few years will allow you 
to enter the CMOS by pressing one of the below five keys during the boot. Usually it's one 
of the first three. 

Fl 


F10 

A user will know when to press this key when they see a message similar to the below 
example as the computer is booting. Some older computers may also display a flashing block 
to indicate when to press the Fl or F2 keys. 

Press < F2 > to enter BIOS setup. 

Once you've successfully entered the CMOS setup you should see a screen similar to the 


Figure 11-1. 


Phoenix ~ AwardBIOS CMOS Setup Utility 
Standard CMOS Features 


Date (mm:dd :yy) àt, May 14 2885 Item Help 
Time (hh:mm:ss) 13 : 33 : 25 


IDE Primary Master [SRMSUNC SP8882N] 


IDE Primary Slave { None] 
IDE Secondary Master [ATAPI CD-ROM 52XMa] 
IDE Secondary Slave [SONY CD-RM CRX32] 


Drive f [1,44M, 3.5 in.J 
Drive B [None] 


Video CECAAA] 
Halt On [Alt , But Keyboard] 


Boren 


tl++:Move Enter:Select +/-/PU/PD:Value F1G:Save ESC:Exit Fl:Gemeral Help 
F5: Previous Values F6: Fail-Safe Defaults F7: Optimized Defaults 


Figure 11-1 BIOS Setup Standard CMOS Features 
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ist Boot 
end Boot 
rd Boot Device 
Boot From Other 


Phoenix 


Device 


fwardBlOS CMOS Setup 
Boot Sequence 


[Floppy] 


[Hard Disk! 


[L51260] 
[Enabled] 


ist Boot Device 


Utility 


| Item Help 


Figure 11-2 BIOS Setup Boot Sequence 


USB Controller 
USB 2.8 Controller 
USB Keyboard 
USB Mouse Support 
fizalia^hC97 Audio 
Onboard UIA6410 RAID Mode [Disable 
tmboard UliIA6307€CIEEE1394) (Disable: 
ünboard Intel LAN : 
> 10 Devices 


Onboard Lan 


Phoenix 


support 


Configuration 
> IDE Devices Configuration [Press Ente 


ROM 


fiuardBIUOS CMOS Setup Utility 


Integrated Peripherals 


Select [Disable 


[Ena ) Ü 


[Press Ente 


> SATA Devices Configuration(Press Enter 


[Disable 


Iten Help 


Figure 11-3 BIOS Setup Integrated Peripherals 


批 注 
(1) IDE: 集成 开发 环境 
(2) Primary Master; 主人 硬盘 
(3) Primary Slave; Mff Zi 
(4) General Help; 一 般 帮 助 
(5) Item Help: 项 目 帮助 


(6) Boot Sequence: 启动 顺序 
(7) CD-ROM: 只 读 光 盘 驱 动 器 


(9) Boot Device: 启动 设备 
(10) LAN; 局 域 网 


AGP Aperture Size 
applications 

boot device 

boot sequence 
CD-ROM 

delay prior to thermal 
device configuration 
DRAM 


rn re SS M co - 


(名 词 ) 
(名 词 ) 
(名 词 ) 
(名 词 ) 
(名 词 ) 
(名 词 ) 
(名 词 ) 
(名 词 ) 


Words and Phrases 


AGP 孔径 大 小 

应 用 程序 

启动 设备 

启动 顺序 

只 读 光 盘 了 驱动 器 

延迟 前 热 

设备 设置 
动态 随机 存 取 存 储 器 

. 143 - 


environment subsystems n. (名 词 ) 环境 子 系统 
general Help n. (名 词 ) 一 般 帮 有 助 

IDE n. (名 词 ) 集成 开发 环境 
item help n. (名 词 ) TH E A By 
kernel n. (474) 内 核 

LAN n. (名 词 ) 局 域 网 
latency time n. (名 词 ) FE 3R AY [8] 
memory hole n. (474) 存储 器 和 孔 
primary master n. (名 词 ) EX E. 
primary slave n. (名词 ) JA 88 3 

service n. (474) 服务 

shell n. (474) 框架 

system BIOS cacheable n. (名 词 ) 系统 BIOS 缓存 
system processes n. (名 词 ) 系统 进程 
system service dispatcher n. (474) 系统 服务 调度 
system thread n. (名 词 ) 系统 线程 
USB n. (474) 通用 串 行 总 线 
USB controller n. (名 词 ) USB 控制 器 


Associated Reading 


Benefits & Risks of Artificial Intelligence 


What is AI? 


From SIRI to self-driving cars, artificial intelligence ( AI) is progressing rapidly. 
While science fiction often portrays? AI as robots with human-like characteristics, AI can 
encompass anything from Google's search algorithms to IBM's Watson to autonomous 
weapons. 

Artificial intelligence today is properly known as narrow AI (or weak AI) , in that it is 
designed to perform a narrow task (e. g. only facial recognition or only internet searches or 
only driving a car). However, the long-term goal of many researchers is to create general AI 
( AGI or strong AI). While narrow AI may outperform humans at whatever its specific task 
is, like playing chess or solving equations, AGI would outperform humans at nearly every 


cognitive task. 
Why research AI safety? 


In the near term, the goal of keeping AI’s impact on society beneficial motivates 
: 144. 


research in many areas, from economics and law to technical topics such as verification, 
validity, security and control. Whereas it may be little more than a minor nuisance if your 
laptop crashes or gets hacked, it becomes all the more important that an AI system does what 
you want it to do if it controls your car, your airplane, your pacemaker, your automated 
trading system or your power grid. Another short-term challenge is preventing a devastating 
arms race in lethal autonomous weapons. 

In the long term, an important question is what will happen if the quest for strong AI 
succeeds and an AI system becomes better than humans at all cognitive tasks. As pointed out 
by I. J. Good in 1965, designing smarter AI systems is itself a cognitive task. Such a system 
could potentially undergo recursive self-improvement, triggering an intelligence explosion 
leaving human intellect far behind. By inventing revolutionary new technologies, such a 
superintelligence might help us eradicate war, disease, and poverty, and so the creation of 
strong AI might be the biggest event in human history. Some experts have expressed 
concern, though, that it might also be the last, unless we learn to align the goals of the AI 
with ours before it becomes superintelligent. 

There are some who question whether strong AI will ever be achieved, and others who 
insist that the creation of superintelligent AI is guaranteed to be beneficial. At FLI we 
recognize both of these possibilities, but also recognize the potential for an artificial ( the 
Future of Life Institute ) intelligence system to intentionally or unintentionally cause great 
harm. We believe research today will help us better prepare for and prevent such potentially 


negative consequences in the future, thus enjoying the benefits of AI while avoiding pitfalls. 
How can AI be dangerous? 


Most researchers agree that a superintelligent’? AI is unlikely to exhibit human emotions 
like love or hate, and that there is no reason to expect AI to become intentionally benevolent 
or malevolent. Instead, when considering how AI might become a risk, experts think two 
scenarios most likely: 

The AI is programmed to do something devastating: Autonomous weapons are artificial 
intelligence systems that are programmed to kill. In the hands of the wrong person, these 
weapons could easily cause mass casualties. Moreover, an AI arms race could inadvertently 
lead to an AI war that also results in mass casualties. To avoid being thwarted by the enemy, 
these weapons would be designed to be extremely difficult to simply "turn off," so humans 
could plausibly lose control of such a situation. This risk is one that's present even with 
narrow AI, but grows as levels of AI intelligence and autonomy increase. 

The AI is programmed to do something beneficial, but it develops a destructive method 
for achieving its goal; This can happen whenever we fail to fully align the ATI's goals with 
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ours, which is strikingly difficult. If you ask an obedient intelligent car to take you to the 
airport as fast as possible, it might get you there chased by helicopters and covered in vomit, 
doing not what you wanted but literally what you asked for. If a superintelligent system is 
tasked with a ambitious geoengineering project, it might wreak havoc with our ecosystem as a 
side effect, and view human attempts to stop it as a threat to be met. 

As these examples illustrate, the concern about advanced AI isn't malevolence but 
competence. A super-intelligent AI will be extremely good at accomplishing its goals, and if 
those goals aren't aligned with ours, we have a problem. You're probably not an evil ant- 
hater who steps on ants out of malice, but if you're in charge of a hydroelectric green energy 
project and there's an anthill in the region to be flooded, too bad for the ants. A key goal of 


AI safety research is to never place humanity in the position of those ants. 
Why the recent interest in AI safety 


Stephen Hawking, Elon Musk, Steve Wozniak, Bill Gates, and many other big names 
in science and technology have recently expressed concern in the media and via open letters 
about the risks posed by AI, joined by many leading AI researchers. Why is the subject 
suddenly in the headlines? 

The idea that the quest for strong AI would ultimately succeed was long thought of as 
science fiction, centuries or more away. However, thanks to recent breakthroughs, many AI 
milestones, which experts viewed as decades away merely five years ago, have now been 
reached, making many experts take seriously the possibility of superintelligence in our 
lifetime. While some experts still guess that human-level AI is centuries away, most AI 
researches at the 2015 Puerto Rico Conference guessed that it would happen before 2060. 
Since it may take decades to complete the required safety research, it is prudent to start 
it now. 

Because AI has the potential to become more intelligent than any human, we have no 
surefire way of predicting how it will behave. We can't use past technological developments 
as much of a basis because we've never created anything that has the ability to, wittingly or 
unwittingly, outsmart us. The best example of what we could face may be our own 
evolution. People now control the planet, not because we're the strongest, fastest or biggest, 
but because we're the smartest. If we're no longer the smartest, are we assured to remain in 
control? 

FLT s position is that our civilization will flourish as long as we win the race between the 
growing power of technology and the wisdom with which we manage it. In the case of AI 
technology, FLI’s position is that the best way to win that race is not to impede the former, 
but to accelerate the latter, by supporting AI safety research. 
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The top myths about advanced AI 


A captivating conversation is taking place about the future of artificial intelligence and 
what it will/should mean for humanity. There are fascinating controversies where the world's 
leading experts disagree, such as; AI’s future impact on the job market; if/when human- 
level AI will be developed; whether this will lead to an intelligence explosion; and whether 
this is something we should welcome or fear. But there are also many examples of of boring 
pseudo-controversies caused by people misunderstanding and talking past each other. To help 
ourselves focus on the interesting controversies and open questions — and not on the 


misunderstandings — let's clear up some of the most common myths shown in Figure 11-4. 


| It may happen in 
decades, centuries 
or never: Al experts 
Superinteligence ^ [»[s|V[z|»|»|»| disagree & we 
by 2100 is impossible [s|v|»|»|v| | | simply don't know 


Only Luddites Many top Al 
worry about AI researchers 
are concerned 


Mythical worry: Actual worry: 


Al turning evil t | Al turning competent, N 
) with goals 

misaligned with ours Us 

Al turning conscious 


| | 
Robots are the Misaligned intelligence 
main concern is the main concern: 
it needs no body, only 
an internet connection 


Myth: 

Al can't control Intelligence 

humans enables control: 
we control tigers 
by being smarter 


Myth: 


Machines can't A heat-seeking 
have goals missile has 


PLAN 
Superintelligence PANIC! It’s at least 


decades away, AH EAD! 


but it may take that 
long to make it safe 


is just years away 


Figure 11-4 Myths and Facts about AI 
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He 注 
(1) artificial intelligence ; 人工 智能 
(2) portray :描绘 ; 描述 ; 画像 ; 描画 
(3) superintelligent: 超 智能 
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附录 A 计算 机 专业 英语 主要 句 型 及 翻译 技巧 


专业 英语 的 句 型 ,复合 请 句 .复杂 长 句 较 多 ,由 于 人 研究 的 对 象 多 为 客观 事物 ,因此 篆 用 
形式 主语 和 形式 宾语 、 名 词 结构 和 被 动 语 态 。 为 外 ,在 时 态 上 ,因为 多 是 介绍 事实 , 故 多 用 
现在 时 。 

专业 喘 语 句 型 的 学 习 , 在 于 长 期 积累 ,通过 句 型 的 学 习 和 总 结 , 有 利于 等 握 英 语 表 达 
习惯 ,因此 应 该 加 强 这 方面 的 积累 和 训练 。 在 平时 的 学 习 总 结 过 程 中 ,建议 根据 应 用 场景 
对 句 型 进行 分 类 ,这 样 便于 记忆 和 应 用 。 本 市 结合 应 用 的 场景 对 常见 专业 英语 句 型 进行 
分 类 说 明 。 


A.1 计算 机 专业 美语 主要 句 型 


1) 基本 定义 : 常见 于 对 新 事物 进行 定义 说明 

(1) A connected graph that contains no simple circuits is called a tree. 

包含 无 简单 回路 的 连接 图 称 为 树 。 

(2) Devices that provide input or output to the computer are called peripherals. 

对 计算 机 提供 输入 与 输出 的 设备 称 为 外 围 设备 。 

(3) I/O is the means by which a computer exchanges information with the outside 
world. 

LO 是 计算 机 通过 它 可 以 与 外 部 交换 信息 的 工具 。 

(4) The term DSL refers to digital subscriber line service. 

术语 DSL 是 指数 字 用 户 专 线 服务 。 

(5) The base, or radix of a number system is defined as the number of different 
digits. 

基数 是 定义 在 数字 系统 中 每 一 位 上 的 不 同 数 字 的 个 数 。 

(6) We call the INSERT operation on a queue ENQUEUE. 

我 们 称 对 队列 进行 的 插入 操作 为 人 队 。 

2) 用 于 比较 : 常见 于 为 反映 事物 的 某 项 功能 ,和 具有 一 定 可 比 性 的 事物 进行 比较 

(1) Just as the CPU controls the computer ( in addition to its other functions) , the 
control unit controls the CPU. 

IH] CPU 控制 整个 计算 机 (除了 其 他 功能 外 ) 一 样 ,控制 单元 控制 CPU. 

(2) Compared to CPU ,the speed of the main memory is often slow. 

与 CPU 相 比 , 主 存 的 速度 通常 比较 慢 。 

(3) Buses use less space on a circuit board and require less power than a large number 
of direct connections. 
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与 大 量 的 直接 连接 相 比 ,总 线 使 用 较 少 的 电路 板 空 间 , 耗 能 更 少 。 

(4) Unlike an array, though, in which the linear order is determined by the array 
indices, the order in a linked list is determined by a pointer in each object. 

不 同 于 数组 的 顺序 由 数组 下 标 确 定 ,链表 的 顺序 由 每 个 对 象 的 指针 确定 。 

(5) Similarly, both the next field of the tail and the prev field of the head point to 
nill. 

类 似 地 , 队 尾 的 next 域 和 队 头 的 prev 域 都 指 回 nill, 

3) 功能 .用途 说 明 : 和 常用 于 直接 介绍 某 个 对 象 的 作用 和 功能 ,或 者 使 用 中 应 注意 的 
事项 

(1) A microprocessor typically performs a sequence of operations to fetch, 
decode, and execute an instruction. 

典型 的 微 处 理 融 执行 取 指 令 、 译 指令 和 执行 指令 等 一 系列 操作 。 

(2) Computers have been widely used in our daily life. 

计算 机 已 经 广泛 用 于 我 们 的 日 贡生 活 。 

(3) Its use is restricted to applications where high speed is unnecessary. 

它 仅 用 于 无 须 高 速 的 情形 。 

(4) ROM is typically used to store the computer's initial start-up instructions. 

ROM 篆 被 用 于 存储 计算 机 的 初始 局 动 指令 。 

(5) Linked lists provide a simple, flexible representation for dynamic sets. 

链表 为 动态 集合 提供 了 简单 .灵活 的 表示 形式 。 

4) 因 采 关系 

(1) Since the program counter is ( conceptually) just another set of memory cells, it 
can be changed by calculations done in the ALU. 

由 于 程序 计数 需 是 另 一 套 存储 需 单 元 ,因而 它 能 被 ALU 中 完成 的 计算 所 修改 。 

(2) An interrupt which can cause the computer to stop executing instructions where it 
was and do something else instead. 

中 断 能 使 计算 机 停止 正在 执行 的 指令 , 转 而 执行 其 他 程序 。 

(3) If prev[ x | = NIL, the element x has no predecessor and is therefore the first 
element, or head, of the list. 

prev[ x] = NIL 表示 元 素 x WA ANE, A x 是 第 一 个 元 素 , 即 队 头 元 素 。 

(4) An empty list consists of just the sentinel, since both next| nill | and prev | nill | 
can be set to nill. 

一 个 空 表 只 包含 标志 符 , 因 为 指针 域 next[ nill] 和 prev[ nill ] 45755] nill, 

5) 组 成 情况 : 常用 于 反映 软件 或 硬件 的 组 成 和 结构 情况 

(1) Inside each of these parts are trillions of small electrical circuits which can be 
turned off or on by means of an electronic switch. 

在 这 些 部 件 的 内 部 是 数 以 万 亿 计 的 小 的 电子 电路 ,这 些 电 子 电 路 能 够 通过 一 个 电子 
开关 关闭 或 打开 。 
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(2) Internally, The CPU has three sections, as shown in Figure 2-3. 

CPU 内 部 有 三 大 分 区 ,如 图 2-3 所 示 。 

6) 时 间 摘 述 

毕 用 于 表达 不 同事 物事 件 发 生 的 时 间 关 系 ,通常 是 先后 或 同步 关系 。 时 间 可 以 是 
一 段 时 间 ,也 可 以 是 一 个 时 间 点 。 

(1) During the fetch portion of the instruction cycle, the processor first outputs the 
address of the instruction onto the address bus. 

4648 5] AY BS Br Ex , ba EI TCR e HUE dS h SEHE ARE 

(2) At the end of the instruction fetch, the CPU reads the instruction code from the 
system data bus. 

在 取 指 令 结束 时 ,CPU 从 系统 数据 总 线 上 读 取 指令 人 码 。 

(3) One such mechanism, the instruction pipeline, allows the CPU to fetch one 
instruction while simultaneously executing another instruction. 

这 些 机 制 中 有 一 种 是 指令 流水 线 技术 , 它 允 许 CPU 在 执行 一 条 指令 的 同时 取出 男 一 
条 指令 。 

7) 其 他 句 型 

(1) Data is transferred via the data bus. 

数据 是 通过 数据 总 线 传 输 的 。 

(2) The INAC instruction of the Relatively Simple CPU can be executed without 
accessing memory or I/O devices, 

相对 于 简单 CPU 的 INAC 指令 ,不 用 访问 存储 硕 或 O 设备 即 可 执行 。 

(3) We now look at how the computer performs these operations from a system 
perspective. 

我 们 从 系统 的 角度 看 计算 机 是 怎样 执行 这 些 操作 的 。 

(4) This is done entirely within the microprocessor. 

3X — 2b 56 A TE AUS PE d P TEN o 

(5) At this point, the microprocessor has fetched the instruction. 

至 此 , 微 处 理 带 已 经 取得 了 指令 。 

(6) When the READ signal is asserted, the memory subsystem places the instruction 
code to be fetched onto the computer system's data bus. 

读 信 号 发 出 后 ,存储 锅子 系统 就 把 要 取 的 指令 码 放 到 计算 机 的 数据 总 线 上 。 

(7) It becomes more efficient ( in terms of minimizing connections) at using buses 
rather than direct connections between every pair of devices. 

使 用 总 线 比 在 每 个 设备 对 之 间 直 接连 接 要 有 效 得 多 ( 就 减少 连接 数量 而 言 ) o 

(8) The desire for reliability led designers to use these devices so that they were 
essentially in one of two states, fully conduction or non-conducting. A simple analogy 
may be made between this type of circuit and an electric light. 

可 靠 性 的 要 求 使 设计 者 采用 这 些 装 置 ,它们 基本 上 处 于 两 个 状态 之 一 : 完全 导 通 或 
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截止 。 在 这 种 电路 和 电灯 之 间 可 以 做 简单 的 模拟 。 

(9) At any given time the light ( or transistor) is either on ( conducting) or off 
( not conduction ) . 

在 任意 给 定 的 时 间 里 ,电灯 (或 晶体 管 ) 处 于 导 通 或 截止 状态 之 一 。 

(10) Even after a bulb is old and weak, it is generally easy to tell if it is on 
or off. 

即使 电灯 泡 很 旧 , 一 般 也 很 容易 区 分 它 是 开 或 关 的 状态 。 

(11) Because of the large number of electronic parts used in computers, it is highly 
desirable to utilize them in such a manner that slight changes in their characteristics 
will not affect their performance. 

由 于 计算 机 中 使 用 了 大 量 的 电子 器 件 ,因此 非常 希望 它们 拥有 这 样 的 特性 , 即 当 特 性 
稍 有 变化 时 ,不 至 于 影响 性 能 。 

(12) Note that these 32 subsets include T itself and the empty set, which contains no 
elements at all. 

应 该 注意 到 ,这 32 个 子 集 中 包含 T 本 身 和 空 集 , 空 集 是 不 含 任何 元 素 的 集合 。 

(13) Given a subset of T, such as S, we may define the complement of S with 
respect to a universal set T to consist of precisely those elements of T which are not 
included in the given subset. 

给 定 工 的 一 个 子 集 , 如 子 集 S ,可 以 定义 一 个 关于 全 集 工 的 S 的 补 集 , 其 中 正好 包含 
不 在 子 集 S 中 而 在 工 中 的 元 系 。 

(14) Thus, S as above defined has its complement ( with respect to T). 

于 是 ,如 上 定义 的 集合 S 就 有 一 个 它 的 补 集 ( 相 对 于 集合 T) 。 

(15) It can be shown that the finite Boolean algebras are precisely the finite set 
algebras. 

很 显然 ,有 限 布 尔 代数 一 定 是 有 限 集合 代数 。 

(16) While it is possible to use a different symbol to denote each element of a 
Boolean algebra, it is often more useful to represent the 2^ elements of a finite Boolean 
algebra by binary vectors having n components. 

虽然 可 以 用 不 同 的 符号 表示 布尔 代数 中 的 每 一 个 元 素 ,但 最 常用 的 方法 是 用 一 个 有 
n 个 分 量 的 二 进 制 向 量 表示 一 个 有 限 布 尔 代 数 的 2" 个 元 素 。 

(17) In the remainder of this section, we assume that the lists with which we 
are working are unsorted and doubly linked. 


在 这 一 节 以 后 的 内 容 中 ,假定 我 们 讨论 的 都 是 无 序 的 双向 列表 。 
A.2 计算 机 专业 英语 翻译 方法 和 技巧 
专业 英语 的 文章 内 容 多 是 描述 客观 事实 ,通常 结构 非常 严 弄 ,逻辑 性 很 强 ,所 用 专业 


词汇 较 多 ,缩写 较 多 。 
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1. 专业 词汇 的 翻译 


(1) 选择 合适 的 词义 。 
有 些 词语 在 不 同 的 领域 和 场合 下 词义 不 同 , 必 须 结合 其 所 在 应 用 领域 翻译 。 下 面 用 
X A-1 说 明 这 一 现象 。 


X A-1 部 分 日 常 单词 在 计算 机 领域 中 的 翻译 


单 du 通常 情况 计算 机 领域 
character 字符 
access 访问 , 存 取 
driver 驱动 程序 
architecture 体系 结构 
instruction 指令 
cache 藏身 处 缓存 ,高速 缓冲 存储 器 
traffic 交通 流量 


通常 ,这 些 单词 的 日 党 翻译 和 计算 机 中 的 翻译 存在 一 定语 义 上 的 关联 。 要 能 够 精准 
翻 详 成 计算 机 术语 ,需要 长 期 积累 ,结合 词义 ,才能 达到 精确 的 专业 翻 详 。 

(2) 统一 翻 详 习惯 。 

计算 机 专业 名 词 的 术语 ,一 般 结 合 专业 翻译 的 习惯 ,统一 翻译 成 同一 个 词语 , 见 
K A-2, 


R A-2 部 分 常见 易 违 反 习 惯 的 翻译 


i] — i8 习惯 翻译 非 习 惯 的 翻译 
外 围 设备 external equipment 
compatible 一 致 性 , 相 容 的 
response Tf] Ju 回答 

browser 浏览 大 阅读 需 


在 翻译 习 惯 中 ,特别 是 对 于 一 些 中 详 喘 的 情况 ,如 采 绪 合 字 面 意思 翻译 ,容易 造成 词 
义 的 偏差 较 大 。 在 喘 译 翻译 中 ,同样 也 需要 遵循 一 定 的 翻译 习惯 ,这 就 需要 加 强 计算 机 专 
业 英 语 的 学 习 , 以 达到 翻译 精准 统一 的 目标 。 

(3) 新 疗 的 详 法 。 

当 遇 到 一 些 专业 新 词语 时 ,可 以 根据 原 词 的 含义 采用 适当 的 方法 加 以 翻译 。 下 面 仅 
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以 一 些 曾 经 出 现 过 的 新 词汇 说 明 翻 详 的 技巧 。 
(D 音译 法 
音 详 法 按 术 请 的 发 音译 出 ,如 bit 翻译 为 比特”; 又 如 ,Ethernet 翻译 为 “以太 网 ”。 
意译 法 
意译 法 是 结合 该 词 表达 的 含义 进行 翻译 ,如 microcomputer 翻译 为 “微机 ” ;又 如 ,bare 
computer 翻译 为 “ 禄 机 ”; 骨 如 ,open source 翻 详 为 “开源 ”。 


2. 语句 的 翻译 技巧 


专业 英语 的 翻译 ,首先 需要 注重 理解 语句 本 号 的 含义 ,在 明确 语句 本 号 含义 的 前 提 
下 ,上 青 结 合 中 文 和 英文 的 表达 习惯 和 表达 方式 进行 翻译 。 这 主要 体现 在 表达 顺序 的 习惯 、 
词义 搭配 习惯 上 。 男 外 ,在 专业 用 语 上 ,要 体现 专业 性 的 表达 习惯 。 翻 译 是 一 种 艺术 ,如 
何 精准 地 找到 对 应 语言 的 相应 词汇 ,除了 和 营 握 一 定 的 翻 详 方法 和 技巧 外 ,还 需要 对 语言 的 
表达 差异 性 有 座 入 的 理解 和 长 期 的 翻译 经 验 积累 。 下 面 介绍 一 些 专业 英语 的 翻译 技巧 。 

(1) 体现 实 义 性 ,不 拘泥 于 语法 。 

计算 机 专业 英语 在 应 用 领域 体现 了 一 种 实 义 性 。 也 就 是 说 ,计算 机 专业 英语 用 词 市 
省 ,句子 精练 .采用 实 义 词汇 而 不 拘泥 于 完整 语法 ,只 要 能 说 明 问 题 ,阐述 中 心思 想 即 可 。 
例如 

(D 讲究 语法 但 不 拘泥 于 语法 。 

You will need the user's manual in order to move up from Sunday driver to UNIX 
speedster. 

为 了 从 UNIX 系统 的 初学 者 成 为 一 名 熟练 者 ,最 好 使 用 用 户 手册 。 

D 赋予 虚词 实际 意义 。 

There is no if in the case 句 中 的 让 就 被 赋予 了 实际 意义 。 句 意 : 这 里 没有 假设 的 
余地 。 

3) 词性 转换 翻译 

His computer is passworded, I can't use. 

他 给 计算 机 加 了 密码 ,我 不 能 使 用 。 

(4) 典故 与 专用 术语 

This 1s the Achilles’ heel which makes MS-DOS an unsuitable for integrating information 
equipment. 

直译 : 这 是 阿 喀 留 斯 的 脚跟 , 它 使 MS-DOS 不 适合 作为 信息 设备 集成 的 运载 体 。 

参考 译文 : 这 是 MS-DOS 的 一 个 致命 弱点 ,使 它 不 适合 作为 信息 设备 集成 的 媒体 。 

Achilles’ heel 是 希 脂 神话 中 的 一 个 故事 , 希 神 阿 咯 留 斯 出 生 后 被 他 的 母亲 倒 提 者 在 
冥 河水 中 浸 过 ,除了 未 浸 到 水 的 脚跟 外 , 浑 映 刀 枪 不 入 ,所 以 他 的 脚跟 就 成 了 其 致命 弱点 。 

(2) Wins] HIE o 

CD 顺序 翻译 。 当 原文 的 被 动 语句 直接 翻译 成 汉语 的 被 动 句 ,又 符合 汉语 习惯 时 ,可 
顺序 翻译 。 

例如 ,It can be automatically generated by a compiler. 
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可 翻译 为 : EA AR C0) — PS VE ae AME 

(2) 翻译 成 主动 句 。 当 翻译 成 汉语 时 ,如 不 符合 中 文 表达 习惯 ,可 以 译 为 主动 句 。 这 
类 情况 常见 于 一 些 词 汇 ,如 expect,require , supply ,need 和 cause 等 。 例 如 ,No return value 
is required. 

可 以 翻 详 为 : 不 需要 返回 数据 。 

(3) 固定 习惯 译 法 。 

在 专业 英语 中 有 一 些 固定 结构 ,可 以 采用 已 有 的 习惯 译 法 。 例 如 ,It has been widely 
used in... PJ ABE: 它 广 泛 用 于 …… ;又 如 ,It lays a solid foundation for... A] LA MEA: 
为 ……… 打下 了 坚实 的 基础 ;再 如 ,With the development of 可 以 翻译 为 : 随 着 ……… 的 发 展 。 

(4) 复杂 句 的 翻译 。 

在 专业 英语 中 ,复杂 句 \ 长 句 较 多 ,对 于 复杂 句 的 翻译 ,首先 需要 把 握 好 主干 部 分 , 即 
主 句 ,以 及 主 句 与 从 名 之 间 存 在 的 逻辑 关系 ,通过 恰当 的 连词 将 句子 拆 开 翻译 ,或 将 一 个 
复 末 句 拆 分 成 几 个 简单 句 。 然 后 将 一 些 附加 成 分 (如 介词 短语 分 词 短 语 、 同 位 语 、 定 诸 
从 名 插入 语 ) 翻译 在 合适 的 位 置 , 在 正确 理解 语句 含义 的 基础 上 ,注意 翻译 时 语句 的 表 
X2 $8 EUR ,避免 上 收 义 .主语 不 明确 .逻辑 混乱 等 情况 发 生 。 下 面 举例 说 明 该 翻译 技巧 。 

例句 : The World Wide Web, or Web for short, is one of the Internet's most popular 
services, providing access to over one billion Web pages, which are documents created in a 
programming language called HTML and which can contain text, graphics, audio, video, 
and other objects, as well as “hyperlinks” that permit a user to jump easily from one page to 
another. 

翻译 : 全 球 信 息 网 ,或 简称 万 维 网 ,是 因特网 上 最 流行 的 服务 之 一 ,提供 对 10 亿 多 网 
页 的 访问 ,这 些 网 页 是 由 一 种 叫 作 HIML( 超 文本 链接 标示 语言 ) 的 编程 语言 生成 的 文 
件 , 它 可 以 包含 本 文 图 形声 频 视频 和 其 他 对 象 ,以 及 允许 用 户 容易 地 跳跃 到 其 他 网 页 
的 “ 超 链 接 ”。 

分 析 : 首先 把 握 语句 的 主 十 部分, 即 全 球 信息 网 是 因特网 上 最 流行 的 服务 之 一 。 然 
后 分 析 “providing access to over one billion Web pages”, 这 是 一 个 “动词 + ing” 的 方式 引 
导 的 状语 从 句 ,相当 于 并 列 谓语 ,可 以 直接 翻译 为 :“ 提 供 对 10 亿 多 网 页 的 访问 ”。 青 分 
Hri“ which are documents created in a programming language called HTML”, 这 是 一 个 
which 引导 的 非 限 定性 定语 从 句 ,可 以 单独 作为 一 条 语句 翻译 ,但 须 明 确 主语 为 “这 些 
网 页 ”。 

(5) 翻译 的 语序 。 

这 是 指 结 合 中 文 语言 习惯 ,将 一 些 以 when not---until after 等 连词 引导 的 从 句 , Ze 
译 时 结合 情况 将 语句 的 翻译 顺序 重新 排列 ,在 汉语 中 常常 把 句子 重心 放 在 后 面 。 如 : 
Without the availability of well-specified and functional user-network interface characteristics 
and the assurance that the network transport function can be achieved using whatever 
technique best meets the end user's needs, but resulting in no additional interface problems, 
these goals of ISDN will not be realized. 

该 句 可 以 翻译 为 :“ 在 没有 规范 良好 的 用 户 接口 特性 和 不 能 保证 使 用 任何 满足 终端 
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用 户 需要 的 技术 也 可 以 实现 网 络 传输 功能 的 情况 下 ,就 算 不 会 引起 别 的 接口 问题 ,ISDN 
的 这 些 目标 也 不 可 能 实现 。 

又 如 : Because of the large number of electronic parts used in computers, it is highly 
desirable to utilize them in such a manner that slight changes in their characteristics will not 
affect their performance. 

AAT ABIRE: PL PCR r6 mat ,强烈 要 求 利用 它们 的 一 些 特 
性 , 即 当 特 性 稍 有 变化 时 ,不 至 于 影响 性 能 。” 


A.3 通用 英语 翻译 方法 


1. 省 译 法 


这 是 与 增 译 法 对 应 的 一 种 翻译 方法 , 即 删 去 不 符合 目标 语 的 思维 习惯 .语言 习惯 和 表 
达 方 式 的 词 ,以 避免 译文 素 葡 。 增 详 法 的 例句 反之 即 可 。 例 如 : 

(1) You will be staying in this hotel during your visit in Beijing. 

你 在 北 束 访 问 期 间 就 住 在 这 家 饭店 里 。( 省 详 物 主 代词 ) 

(2) I hope you will enjoy your stay here. 

硕 望 你 在 这 儿 过 得 愉快 。( 省 译 主语 ) 

(3) The Chinese government has always attached great importance to environmental 
protection. 

中 国政 府 历 来 重视 环境 保护 工作 。( 省 详 名 词 ) 

(4) The development of IC made it possible for electronic devices to become smaller 


and smaller. 


4E VN, FR, Fi PIS] A JR Fe Lr n] WBS BOR BY), (PETE SA ETE it) 
2. 增 译 法 


根据 英汉 两 种 语言 不 同 的 思维 方式 .语言 习惯 和 表达 方式 ,在 翻 详 时 增添 一 些 词 | 
句 或 句子 ,以 便 更 准确 地 表达 出 原文 包含 的 意义 。 例 如 : 

(1) Indeed, the reverse is true. 

实际 情况 恰好 相反 。( 增 译名 词 ) 

(2) This is yet another common point between the computers of the two generations. 

这 是 这 两 代 计 算 机 之 间 的 又 一 个 共同 点 。( 增 译 介 词 ) 

(3) Individual mathematicians often have their own way of pronouncing mathematical 
expressions and in many cases there is no generally accepted “ correct” pronunciation. 

每 个 数学 家 对 数学 公式 常常 有 各 目的 读 法 ,许多 情况 下 并 不 存在 一 个 普遍 接受 的 所 
谓 “正确 " 读 法 。( 增 加 隐 含 意义 的 词 ) 

(4) It is only when confusion may occur, or where he/she wishes to emphasis the 
point, that the mathematician will use the longer forms. 

: 156- 


只 有 在 可 能 发 生 混 消 或 要 强调 其 观点 时 ,数学 家 才 使 用 较 长 的 恋 法 。( 增 加 主语 ) 
3. 转换 法 


在 翻译 过 程 中 ,为 了 使 译文 符合 目标 语 的 表述 方式 .方法 和 习惯 ,对 原 句 中 的 词类 A 
型 和 语 态 等 进行 转换 。 

(1) 在 词性 方面 ,把 名 词 转换 为 代词 ,形容词 .动词 ;把 动词 转换 成 名 词 ,形容词 、 
in] 介词 ;把 形容 词 转换 成 副词 和 短语 。 

(2) 在 句子 成 分 方面 ,把 主语 变 成 状语 \ 定 语 、 宾 语 、 表 语 ; 把 谓语 变 成 主语 定语 、 表 
语 ; 把 定语 变 成 状语 主语 ;把 宾语 变 成 主语 。 

(3) 在 句 型 方面 ,把 并 列 句 变 成 复合 句 , 把 复合 句 变 成 并 列 句 , 把 状语 从 句 变 成 定语 
从 句 。 

(4) 在 语 态 方 面 ,可 以 把 主动 语 态 变 为 被 动 语 态 。 

下 面 通过 一 些 例子 说 明 。 

(1) Too much exposure to TV programs will do great harm to the eyesight of children. 

孩子 们 看 电视 过 多 会 大 大 损坏 视力 。( 名 词 转动 词 ) 


(2) Thanks to the introduction of our reform and opening policy, our comprehensive 


L 


zu 


national strength has greatly improved. 
由 于 我 国 实行 了 改革 开放 政策 ,所 以 我 国 的 综合 国力 有 了 明显 的 增强 。( 动词 转 名 词 ) 
(3) We don't have much time left. Let's go back. 
时 间 不 早 了 ,我 们 回去 吧 ! (名 型 转换 ) 


4. 拆 句 法 和 合并 法 


(1) Increased cooperation with China is in the interests of the United States. 

同 中 国 加 强 合作 ,符合 美国 的 利益 。( 在 主 谓 连接 处 拆 译 ) 

(2) China is a large country with four-fifths of the population engaged in agriculture, 
but only one tenth of the land is farmland, the rest being mountains, forests and places for 
urban and other uses. 

中 国 是 一 个 大 国 ,80% 的 人 口 从 事 农业 ,但 耕地 只 占 土 地 面积 的 1/10 ,其 余 为 山脉 、 
森林 城镇 和 其 他 用 地 。( 合 译 法 ) 

(3) Packet switching is a method of slicing digital messages into parcels called 
" packets," sending the packets along different communication paths as they become 
available, and then reassembling the packets once they arrive at their destination. 

分 组 交换 是 传输 数据 的 一 种 方法 , 它 先 将 数据 信息 分 割 成 许多 称 为 “分 组 ”的 数据 信 
息 包 ; 当 路 径 可 用 时 ,经 过 不 同 的 通信 路 径 发 送 ;到 达 目 的 地 后 ,再 将 它们 组 装 起 来 。( 将 
长 定语 从 句 拆 成 几 个 并 列 的 分 句 ) 


5. 正 译 法 和 反 译 法 


这 两 种 方法 通 稼 用 于 汉 详 英 ,偶尔 也 用 于 瑞 详 汉 。 所 谓 正 详 , 是 指 把 句子 按照 与 汉语 
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相同 的 语 友 或 表达 方式 译 成 喘 语 。 所 谓 反 译 , 则 是 指 把 句子 按照 与 汉语 相反 的 语序 或 表 
达 方 式 译 成 瑞 语 。 正 译 与 反 详 第 党 具有 同 义 的 效果 ,但 反 译 往 往 更 符合 英语 的 思维 方式 
和 表达 习惯 ,因此 比较 地 道 。 

(1) 你 可 以 从 因特网 上 获得 这 一 信息 。 

You can obtain this information on the Internet. ( IE) 

This information is accessible/available on the Internet. ( x if) 

(2) 他 突然 想到 了 一 个 新 主意 。 

Suddenly he had a new idea. ( 1ETÉ) 

He suddenly thought out a new idea. ( IETÉ) 

A new idea suddenly occurred to struck him. ( J TÉ) 


6. 倒置 法 


在 汉语 中 ,定语 修饰 语 和 状语 修饰 语 往 往 位 于 被 修饰 语 之 前 ;在 英语 中 ,许多 修饰 语 
律 常 位 于 被 修饰 语 之 后 ,因此 翻译 时 要 把 原文 的 语序 题 倒 过 来 。 倒 置 法 通常 用 于 严 译 汉 ， 
即 对 英 诸 长 名 按照 汉语 的 习惯 表达 法 进行 前 后 调换 , 按 意 群 ( 指 句子 中 按 意 思 和 结构 划 
分 出 各 个 成 分 ,每 一 个 成 分 即 称 为 一 个 意 群 ) 或 进行 全 部 倒置 ,原则 是 使 汉语 译 句 安排 符 
合 现代 汉语 论 理 叙 事 的 一 般 逻 辑 顺 序 。 有 时 倒置 法 也 用 于 汉 译 英 。 如 : 

(1) At this moment, through the wonder of telecommunications, more people are 
seeing and hearing what we say than on any other occasions in the whole history of the world. 

此 时 此 刻 ,通过 现代 通信 手段 的 奇迹 ,看 到 和 听 到 我 们 讲话 的 人 比 整个 世界 历史 上 任 
何其 他 这 样 的 场合 部 要 多 。( 部 分 倒置 ) 

(2) 改革 开放 以 来 ,中 国 发 生 了 巨大 的 变化 。 

Great changes have taken place in China since the introduction of the reform and opening 
policy. (全 部 倒置 ) 

7. BAK 

这 种 方法 多 用 于 喘 详 汉 。 所 请 包 孕 ,是 指 在 把 类 堵 长 句 详 成 汉 声 时 , OLET UR ELLA 
按照 汉语 的 正常 语序 放 在 中 心 词 之 前 ,使 修饰 成 分 在 汉语 句 中 形成 前 置 包 孕 ,但 修饰 成 分 
不 宜 过 长 ,否则 会 形成 拖 示 或 造成 汉语 句子 成 分 在 连接 上 的 纠葛 。 例 如 

(1) IP multicasting is a set of technologies that enables efficient delivery of data to 
many locations on a network. 

IP 多 信道 广播 是 使 数据 向 网 络 中 许多 位 置 高 效 传送 的 一 组 技术 。 

(2) What brings us together is that we have common interests which transcend those 


differences. 


使 我 们 走 到 一 起 的 ,是 我 们 有 超越 这 些 分 此 的 共同 利益 。 
8. 插入 法 


插入 法 是 指 把 难以 处 理 的 句子 成 分 用 破 折 号 .括号 或 前 后 逗号 插入 详 负 中 。 这 种 方 
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法 主要 用 于 笔译 中 ,偶尔 也 用 于 口译 中 , 即 用 同位 语 \ 插 入 语 或 定语 从 名 处 理 一 些 解 释 性 
成 分 。 例 如 : 
If the announcement of the recovery of Hong Kong would bring about, as Madam put 
it, "disastrous effects," we will face that disaster squarely and make a new policy decision. 
如 宁 说 宣布 收回 香港 就 会 像 夫 人 说 的 “市 来 灾难 性 的 影响 ”, 那 我 们 将 勇敢 地 面 对 这 
个 灾难 ,做 出 决策 。 


9. 重组 法 


进行 英 译 汉 时 ,为 了 使 译文 流畅 和 更 符合 汉语 叙事 论 理 的 习惯 ,在 持 清 秽语 长 句 的 结 
构 弄 异 瑞 语 原音 的 基础 上 ,彻底 摆脱 原文 语序 和 句子 形式 ,对 句子 进行 重新 组 合 。 例 如 . 

Decision must be made very rapidly; physical endurance is tested as much as 
perception, because an enormous amount of time must be spent making certain that the key 
figures act on the basis of the same information and purpose. 

必须 把 大 量 时 间 花 在 确保 关键 人 物 均 根据 同一 情报 和 目的 行事 ,而 这 一 切 对 号 体 的 
耐力 和 思维 能 力 都 是 一 大 考验 。 因 此 ,一 旦 考虑 成 熟 ,决策 者 就 应 迅速 做 出 决策 。 


10. 综合 法 


综合 法 是 指 单 用 某 种 翻译 技 巧 无 法 译 出 时 ,独眼 篇 章 , 以 逻辑 分 析 为 基础 ,同时 使 用 
转换 法 .倒置 法 . 增 译 法 .省 译 法 \ 拆 句法 等 多 种 翻译 技巧 的 方法 。 例 如 . 

Behind this formal definition are three extremely important concepts that are the basis for 
understanding the Internet: packet switching, the TCP/IP communications protocol, and 
client/server computing. 

在 这 个 正式 的 定义 背后 , 隐 含 着 3 个 极其 重要 的 概念 : 分 组 交换 \TCP/IP( 传 输 控制 
协议 /网 际 协议 ) 通 信 协 议和 客户 端 /服务 各 计算 技术 ,它们 是 理解 因特网 的 基础 。 


11. 长 名 翻译 应 用 


正确 分 析 句 子 的 结构 是 正确 翻译 的 基础 ,为 了 做 好 专业 英语 长 句 的 翻译, 要 先 从 长 句 
的 句法 结构 分 析 入 手 。 专 业 瑞 语 的 结构 复杂 的 长 句 , 其 句法 结构 主要 包括 4 个 方面 : 
(大 量 使 用 名 词 化 结构 以 及 垂 甚 结构 压缩 句子 长 度 ; QA FCAT el it 结构 保持 文风 凝重 
平稳 ; 3 常 用 平行 结构 使 层次 清晰 ; (4 使 用 圆周 句 结构 ,从 名 交错 重合。 

英语 中 的 长 句 通 党 结构 复杂 ,修饰 成 分 多 而 不 定 , 看 上 去 无 划 可 循 。 但 是 ,依照 西方 
人 重 逻 辑 和 条 理 , 多 线性 思维 的 特点 ,英语 长 句 多 采取 分 层 结构 ,讲究 主 次 ,所 以 翻译 时 应 
根据 英汉 表达 方式 的 不 同 , 采 取 不 同 的 翻译 方法 将 英语 长 句 目 然 地 用 汉语 表达 出 来 。 通 
笛 采 用 的 方法 有 顺 译 法 . 逆 译 法 分 译 法 以 及 综合 译 法 等 。 下 面 结合 一 些 例子 对 这 些 方 法 
进行 分 析 。 

(1) Moving around the nuclear are extremely tiny particles, called electrons, which 
revolve around the nuclear in much the same way as the nine planets do around the sun. ( 参 
考 译文 : 围绕 原子 核 运 动 的 是 一 些 极 其 微小 的 粒子 , 称 为 电子 ,这 些 电子 围绕 原子 核 放 

- 159. 


转 , 正 像 九 大 行星 围绕 太阳 旋转 一 样 。) 

本 句 中 的 “Moving around the nuclear” 为 动 名 词 短 语 , 在 句 中 作 主 语 ;“ Which 
revolve…sun” 为 非 限制 性 定语 从 名 ,由 关系 代词 which 引导 ,修饰 先行 词 electrons。 经 过 
分 析 , 此 句 结 构 清 晰 ,各 部 分 基本 上 按 人 逻辑 关系 排列 。 这 与 汉语 的 表达 习惯 基本 一 致 ,可 
以 按照 吴语 原文 的 顺序 翻译 成 汉语 ,对 这 类 长 句 的 翻译 采用 的 是 顺 译 法 , 即 先 把 句子 拆 分 
成 意思 单位 ,然后 依次 译 出 ,需要 变化 的 就 随 之 变化 ,使 之 更 符合 汉语 的 表达 习惯 。 

(2) A material which has the property of elasticity will return to its original size and 
shape when the force producing strain are removed. (参考 译文 : 如 果 把 产生 应 变 的 力 去 
掉 , 具 有 弹性 的 材料 就 会 恢复 到 它 原 来 的 体积 和 形状 。) 

本 例 中 由 when 引导 的 时 间 状 语 从 句 ,按照 汉语 的 表达 习惯 位 于 主 句 之 后 的 状语 从 
句 \ 主 语 从 名 等 ,翻译 时 往往 要 放 在 主 句 之 前 ,这 种 译 法 叫 作 逆 译 法 , 即 不 限于 原文 的 形 
式 , 逆 着 原文 的 顺序 翻译 ,把 英语 长 句 中 的 诈 句 置 于 汉语 句 的 末 句 。 

(3) The loads a structure is subjected are divided into dead loads, which include the 
weights of all the parts of the structure, and live loads, which are due to the weights of 
people, movable equipment, etc. (参考 译文 ; —P 254 sz $ AY fay AR n] VA AT Ay f ae f] FA 
Hak fn PAE, A EU d VA TAI pA EI E ; 2n] Je FLA 可 移动 的 设备 等 的 重量 
引起 的 。) 

本 句 有 两 个 并 列 的 宾语 ,分 别 是 由 which 引导 的 非 限 制 性 定语 从 名 。 从 此 例 可 以 看 
出 , 瑞 语 长 名 中 , 主 二 和 从 名 或 修饰 成 分 的 关系 并 不 紧密 ,而 汉语 就 有 篆 稼 使 用 短 句 表达 
的 习惯 。 把 长 句 中 的 从 名 和 修饰 成 分 译 成 短 句 分 开 翻 译 ,这 种 方法 叫 作 分 译 法 。 

(4) More particularly, this invention relates to a method and apparatus for forming a 
film of metal oxides continuously on the surface of ribbon glass by spring thereon a solution 
of metal compounds at a point in the neighborhood of the inlet to a lehr or the inside thereof 
when the ribbons glass is being conveyed to the lehr after it has been formed from molten 
glass. (更 具体 地 说 ,本 发 明 涉 及 在 带 玻 璃 表面 上 连续 地 喷涂 一 层 金 属 氧 化 膜 的 方法 和 装 
置 。 当 玻璃 由 液态 成 型 为 囊 玻 璃 之 后 ,在 其 被 送 往 退火 窗 时 ,从 退火 罕 入 口 附近 或 人 口 里 
将 金属 化 合 物 喷 到 玻璃 表面 。) 

翻译 英语 长 句 时 ,并 不 是 单纯 地 使 用 一 种 翻译 方法 ,而 是 要 求 我 们 综合 使 用 各 种 方 
法 ,以便 把 英语 原文 翻译 成 通顺 忠实 的 汉语 句 。 在 该 例 ,介词 by 的 前 后 句子 表达 的 是 两 
层 意 思 。 前 面 的 语序 和 汉语 相同 ,可 采用 顺 详 法 ;后 面 的 语序 与 汉 培 完全 相反 ,可 采用 逆 
译 法 。 这 样 ,根据 句子 及 修饰 语 的 主 次 .逻辑 .时间 先 后 ,有 顺 有 逆 地 综合 处 理 的 翻译 方法 
叫 作 综 合 译 法 。 


: 160 - 


附录 B 计算 机 专业 美语 的 特点 
B.1 计算 机 专业 英语 的 词汇 特点 


专业 词汇 语法 的 特点 主要 表现 在 专业 术语 较 多 ,合成 义 单一 。 计 算 机 行业 中 不 断 消 
现 出 新 构造 出 来 的 词 ,如 unformat , uninstall 和 blog 等 ,这 些 词 往往 在 词典 中 查 不 到 。 但 
这 些 单 词 的 形成 往往 体现 出 一 定 的 规律 ,这 就 是 构词法 。 擎 握 了 构词法 ,对 于 计算 机 英语 
的 学 习 ,就 可 以 达到 举一反三 见 词 识 义 的 效果 。 篆 用 的 构词法 有 合成 法 、 转 化 法 及 词 绥 


1. 合成 法 


合成 法 是 指 把 两 个 或 两 个 以 上 独立 的 词 按照 一 定 次 序 排列 构成 新 词 的 方法 。 由 这 种 
方法 构成 的 词 具 有 灵活、 机 动 . 善 变 LES fn] AS UI ES, 19] 4I network ( 网络 ) backup ( && 
份 , 已 另外 储存 以 备份 计算 机 发 生 故 障 时 间 的 备份 程序 或 文件 ) , database ( 数据 库 , 指 互 
相关 联 的 事实 或 数字 并 已 计算 机 化 的 表 列 ) dialogue box( 对话 框 ,供用 户 与 计算 机 进行 
一 系列 问答 操作 的 栏 面 ) .harddisk( 硬盘) , hardware (硬件 ) , software (软件 ) , download 
(下 载 ) ,laptop( 笔 记 本 式 计算 机 .便携式 机 ) .offline( 脱 机 ) .homepasge( 主页) , backbone 
(主干 网 ) login( 登 录 , 输 入 用 户 名 和 密码 ,以 使 计算 机 验证 你 是 计算 机 或 网 络 的 合法 用 
p ,并 人 允许 你 使 用 资源 ) 和 logoff 注销 ,停止 使 用 计算 机 或 网 络 时 所 执行 的 步骤 ,通常 是 


一 条 单独 的 命令 ) 。 
BWA GINA : 
e -based; AE T eee 为 基础 。 例 如 ,rate-based: 基于 速率 的 ,credit-based: 基于 信 
党 的 ,file-based: 基于 文件 的 。 
e -oriented: 面 回 ……: 的 。 例 如 ,object-oriented: 面 回 对 象 的 ,market-oriented: 市 场 


导 问 , process-oriented ; 面 回 进程 的 。 

info-: 信息 ,与 信息 有 关 的 。 例 如 ,info-channel: 信息 通道 ,info-tree: 信息 树 ,info- 
world: 信息 世界 。 

event-: 事件 的 。 例 如 ,event-driven: 事件 驱动 的 ,event-oriented: 面 回 事件 的 ， 
event-based. 基于 事件 的 。 

-free: 目 由 的 ,无 关 的 。 例 如 ,paper-free: 无 纸 的 ,jumper-free: 无 跳 线 的 ,lead- 
free: 无 线 的 。 

-centric ， 以 .……. 为 中 心 的 。 例 如 ,client-centric: LAA A AUD AY , user-centric: 以 
用 户 为 中 心 的 ,host-centered: 以 主机 为 中 心 的 。 
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2. 转化 法 


转化 法 是 指 一 种 词类 转换 为 另 一 种 词类 ,转换 后 的 词义 往往 与 原来 词义 有 密切 联系 。 
例如 ,reject(n. 废品 ) 转 化 为 to reject( v. 拒 不 接受 ) , Format( n. 格式 ) 转 化 为 to format 
(v. 格式 化 ) 。 

在 计算 机 秽语 材料 里 ,最 令 人 头疼 的 是 我 们 会 碰 到 一 些 在 一 般 身 语 里 已 经 认识 而 其 
实际 含义 却 与 已 知 意义 大 相 径 庭 的 短语 ,此 时 稍 不 留神 , 便 会 误 入 歧途 , 落 进 “ 陷 阱 ”, 出 
现 差 之 毫 厘 . 失 之 千 里 的 误解 。 


例如 : character ( 特征 、 性 格 、 角 色 ) 一 一 字符 , menu (菜谱 ) 一 一 菜单 .选单 ,program 
( 节日) 一 一 程序 .编程 ,operation ( 手术 ) 操作 , display ( 显示 ) iL AN fit , storage ( JF 


££.) 一 一 存 储 需 ,track( 跑 着 ) ——— 8438 , save ( 挽救 节省 ) — R, mouse ( & BR ) —— BR. 
bi , memory ( i TZ ) —— VJ f£ , bus ( Z HRE) 总 线 , driver ( 25 Ub m ) ——5K oh fé FF , 
monitor( 班长 ) 显示 需 ,enter( EA ) —— [nl E. , key ( 钥匙 ) 一 一 按键 等 。 

在 计算 机 英语 中 ,这 样 的 词汇 很 多 ,都 是 我 们 熟悉 的 初中 级 词汇 ,不 过 含义 已 经 有 所 
不 同 。 所 以 ,在 某 种 意义 上 ,学 习 计 算 机 英语 ,词汇 应 该 不 是 “记忆 ”的 问题 ,而 是 “ 转 义 ” 
的 问题 。 大 部 分 单词 是 熟悉 的 ,只 在 学 习 过 程 中 将 它 对 应 到 计算 机 专业 课程 中 已 经 融 知 
的 专 有 词义 就 可 以 了 。 

3. 词缀 法 


词缀 法 是 指 在 一 个 单词 的 前 面 或 后 面 加 上 一 定 的 词缀 构成 一 个 新 词 的 方法 。 按 照 词 
级 在 词 中 的 位 置 ,可 分 为 前 弘法 和 后 弘法。 在 计算 机 瑞 语 中 , 构 词 能 力 强 的 前 级 有 
* re; reboot 一 重新 起 动 , retry — Eih , Recycle bin 一 回收 站 ,refresh 一 刷新 ,rename 一 
重 命名 ,replay 一 回放 。 
* pre; preview 一 预览 ,preset 一 预 置 ,preprocessor 一 预 处 理 。 
e cyber; cyberspace 一 计算 机 网 络 系统 , cybershop 一 网 络 商 店 , cyberchat 一 网 络 
聊天 。 
e inter: Internet 一 因特网 ,interactive 一 交互 式 的 ,interface 一 接口 ,界面 。 
e micro; Microsoft 一 微软 公司 , microcomputer—{i HL , microprocessor— f AL FEH - 
e multi; multimedia 一 多 媒体 ,multitasking 一 多 任务 ., 
有 关 的 后 级 词 . 
* able; erasable 一 可 探 除 ,programmable 一 可 编程 。 
* or: accelerator— {HEFE , calculator—it 53-25 , 
ise /ize; digitize 一 数字 化 ,maximize 一 最 大 化 ,normalize 一 标准 化 。 
e er. driver—5K oh f£ JF, browser—iXl| Vi #5, server 一 服务 45, scanner—4 ffi 4X, 
hacker 一 黑客 。 


4. 缩 与 词 


缩写 词 是 指 取 词 组 中 每 个 词 的 第 一 个 字母 组 合 构 成 的 新 词 ( 可 参考 附录 C). 。 例 如 ， 
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ALU( Arithmetic Logic Unit ,算术 逻辑 运算 单元 ) ,LAN( Local Area Network , 局 域 网 ) ^5 
5. f&h ig 


借用 词 是 指 借用 公共 英语 及 日 贡生 活用 语 中 的 词汇 表达 专业 含义 。 借 用 词 一 般 来 目 
厂商 名 商标 名 ,产品 代号 名 、 发 明 者 名 .地 名 等 ,也 可 将 普通 公共 瑞 语 词汇 演变 成 专业 词 
义 实 现 , 也 有 对 原来 词汇 赋予 新 的 意义 的 。 


例如 : cache 一 一 高 速 缓存 、 隐 藏 处 所 隐藏 的 粮食 或 物资 贮藏 物 ,Firewall 一 一 防火 
i IS Acl, Flag 一 一 标志 状态、 旋 标记 ,mail-bomb/junk-mail 一 一 邮件 炸弹 ,bomb 一 一 
炸弹 。 


B.2 计算 机 专业 英语 的 语法 特点 


专业 英语 的 语法 特点 : 和 用 形式 主语 和 形式 宾语 ,名 词 结构 和 被 动 语 态 使 用 频繁 , 复 
杂 长 句 多 ,复合 句 多 ,每 句 包 含 信 息 量 大 。 邦 外 ,在 时 态 上 ,叙述 事实 多 用 现在 时 。 

(1) 频繁 使 用 陈述 铅 ,时 态 多 用 现在 时 。 由 于 专业 旭 语 多 描述 一 些 客观 事 实 ,因此 和 甸 
用 陈述 句 表 达 方 式 描 述 。 如 The text you enter into your document is usually just the raw 
material for your finished product. 

(2) 多 用 被 动 语 态 。 由 于 通常 表达 的 对 象 是 物 ,因此 所 用 语 态 为 被 动 语 态 。 如 The 
main memory of most computer 1s composed of RAM. 

(3) 多 使 用 禄 使 句 。 笛 用 于 命令 劝告 .建议 等 介绍 说 明 .前述 实例 等 ,其 主语 往往 省 
Wt. Hl Drag the text to the space in front of the roof. 

(4) 定语 后 置 的 使 用 较 多 。 如 Java is a language very difficult to learn. 

(5) 动词 动词 的 非 谓 语 形式 出 现 频率 比较 高 。 论 述 的 重点 往往 是 事实 现象 或 过 程 ， 
不 涉及 有 关 的 人 , 故 动词 的 被 动 语 态 形式 也 有 很 高 的 出 现 频率 。 如 : 

MENU 一 has not been defined(MENU 一 还 未 定义 ) ;Record appears to be out of place 
(记录 位 置 不 对 ) ; Memory length is not supported and was ignored( A Z F234 fifi te KE IFA 
略 它 ) ;The network is inactive or you are not connected properly ( 此 网 络 是 禁用 的 或 未 正 篆 
连接 ) ;The new password has been used previously , please try again ( 新 口令 先前 已 用 过 ,请 
重 试 ) ;The partition was cleared and the initialization procedure shold be restarted ( 清除 该 盘 
分 区 ,再 重新 局 动 初始 化 过 程 ) 。 动 词 的 非 谓 语 形式 : Extended Dos partition created ( 扩展 
DoS 分 区 已 经 建立 ) , Expected network number missing ( 要 求 的 网 络 号 遗漏 ) ;Error loading 
operatiin system( 半 入 操作 系统 时 出 钳 ) ;No partition to delete( 没 有 可 删除 的 分 区 ) ; 
Insufficient memory to complete fill( 内 存 不 够 ,不 能 完成 填充 工作 ) 。 


B.3 计算 机 专业 英语 的 修辞 特点 
计算 机 专业 英语 属于 科技 英语 ,具有 科技 英语 的 修辞 特点 。 文 体 一 般 是 一 种 客观 的 


叙述 ,用 于 描述 事实 .记录 试验 阐明 规律 或 探讨 理论 。 不 论 是 科学 论文 .科普 论文 ,还 是 
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技术 文本 , filins IURE EB Si Z6 BUR ERI ELA .何洁 、 确 切 的 特点 。 科 技 人 员 注 重 的 
是 科学 事实 和 他 辑 概念 等 ,因而 其 文体 十 分 严 间 , 修 梧 比较 单调 。 许 多 语言 学 者 认为 , 科 
技 语言 应 当 避 免 抒 情 .幽默 比喻 以 及 其 他 任何 沉 有 主观 色彩 的 语言 ,以 免 使 读者 产生 行 
文 浮华 .内容 失真 之 感 。 但 修辞 格 未 必 就 会 削弱 语言 内 容 的 客观 性 ,相反 ,恰当 的 修辞 格 
能 起 到 润滑 剂 的 作用 ,减少 星 深 ,使 行文 流畅 生动 JE SRL T ARR, TEA WE, EF 
拉 文 献 中 采用 适当 的 修 梧 格 ( 如 明 喻 、 上 暗喻 、 提 喻 .拟人 等 ) ,可 以 提升 读者 对 文章 内 容 的 
理解 。 在 计算 机 专业 英语 阅读 和 写作 时 ,要 正确 体会 这 一 点 。 


1. 词语 修辞 


ini 1B he BS AA AY E RB tS E m ( metaphor) , #1 A ( personification ) , 4 5K 
(hyperbole) 仿 拟 (parody) X JE (oxymoron) , ££ 3i ( transferred epithet) , X} H8 ( contrast ) , 
[H4 X ( metonymy ) 及 提 喻 (synecdoche ) SE , 3x HE f RES TE BL eT B EFE P A MISI, e 
计算 机 专业 英语 中 也 不 少见 。 下 面 以 拟人 为 例 介 绍 词语 修 酬 。 

拟人 赋予 各 种 事物 以 人 的 特征 .思想 或 活动 ,或 惠 上 人 的 属性 ,形象 解释 科技 知识 ,使 
内 涵 化 虚 为 实 ,格调 轻松 ,明度 目 然 。 译 文 应 明确 来 洁 , 和 直截了当 ,运用 于 其 中 也 产生 异 曲 
同 工 之 妙 ,增加 审美 想象 力 。 例 如 : 

(1) While many Californians dream of leaving their home state of California, clams 
from Asia, a slug from New Zealand and a jellyfish from the Black Sea have decided to buck 
the trend and take up residence in San Francisco Bay. 

译文 : 正当 许多 加 利 福 尼 亚 人 梦想 看 离开 他 们 的 家 园 时 ,亚洲 的 一 些 蛤 类 新 西 兰 的 
一 种 海参 以 及 生长 在 黑海 的 一 种 水 母 却 拿 定 主义 反 潮 流 ,来 到 旧金山 定居 (将 蛤 类 等 海 
生物 拟人 化 ,“ 拿 定 主 义 反 潮流 ”这 几 个 字 把 它们 的 行为 描述 得 更 加 入 性 化 ,用 在 此 处 来 
与 名 前 人 的 行为 进行 对 比 ) 。 

(2) In the chilly month of November, most U. S. production areas don't have harvest 
fruit. But a team of University of Florida scientists is trying to help growers in Northern 
Florida produce a crop—by tricking strawberry plants into thinking it's spring time. 

译文 : FEEL EY -F— HOSEOS IE Ke BOK DR HE, ANE ORR ART ,佛罗里达 大 
学 的 一 个 研究 小 组 却 正在 演 试 让 佛罗里达 北部 果农 在 这 时 候 也 有 收成 一 一 方法 是 对 草 春 
进行 欺骗 ,让 它们 和 觉得 春天 已 经 来 临 了 (赋予 草 每 以 生命 ,“ 对 草 奏 进行 欺骗 ,让 它们 觉得 
春天 已 经 来 临 了 ”这 几 个 字 让 译文 读者 更 能 够 清楚 地 明日 这 个 研究 小 组 研究 的 实际 
BR ) a 

(3) The technology of millimeter wave guidance is still in its infancy now. 

FEX. SOR OBI S DON HA REE 

(4) Since the early 50s, when naval missiles came of age, the way in which the 
different navies evaluated the level of importance to be attributed to naval gun has been 
marked by ups and downs. 

译文 : AM 20 世纪 50 年 代 初 舰 载 导弹 开始 服役 以 来 ,各 国 海 车 对 舰 炮 重要 性 的 评 
价 就 各 不 相同 。 
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例 (3) 中 的 短语 in its infancy 4149] (4) 中 的 came of age 一 般 用 来 描写 人 ,分 别 表示 
“婴儿 期 ”和 ”成熟 , 到 法 定年 龄 ” ,但 这 里 用 来 说 明 “ 制导 技 术 ” 和”“ 舰 载 导 弹 ” 的 发 展 
情况 。 

(5) "Because this protein comes from a related fungus, the tree thinks it's under 
attack," says Hubbes; “It therefore triggers a cascade of defense reactions. ” 

译文 :“ 因为 这 种 重 日 质 来 日 一 种 相关 真菌 ,所 以 这 棵 树 认 为 目 己 受到 攻击 ”, 哈 布 斯 
说 道 。“ 它 因此 采取 一 连 串 的 防御 性 行动 。”( 作 者 把 树 比 作 人 ,赋予 它 思 想 。 这 是 有 生命 
的 事物 间 的 比拟 ) 

(6) NEC says it has designed the robot to be "cute" , It can doze off and talks in its 
sleep, and will start dancing and playing music if it is petted. 

译文 : 日 本 电气 公司 称 已 设计 出 一 种 灵巧 的 机 需 人 , 它 会 打 瞳 睡 和 说 梦话 。 要 是 你 
拍 它 一 下 , 它 便 开始 跳舞 .演奏 音乐 (无 生命 的 事物 也 可 拟人 化 ) 。 


2. 音韵 修辞 


音韵 修辞 帝 用 的 具体 修辞 格 有 押韵 和 拟 声 (onomatopoeia) 。 它 们 的 合理 运用 能 使 翻 
译 明 快 而 生动 ,富有 节奏 感 ,充分 体现 语言 内 在 的 音乐 美 。 下 面 以 押韵 为 例 分 析 音 韵 
IE RE. 

PERE EAR AIR PT EIE. his éd apos nr 8 EH IRI PEE EE 
使 结构 整齐 深 亮 UE ER A 187 T MUR SR, A ZEE T- Ben AAT SE vds 
RAER, DETTE THA TS HI FIR BY Je ROME PEAY , PEC BE OR ec f Be FE PIER XC 
BABIES SET ES ,获得 形 和 声 两 方面 的 美 。 如 . 

(1) The electronic devices are used in computers as switches that simple turn on 
and off. 

译文 一 : 这 些 电 子 帮 件 在 计算 机 中 起 开关 作用 ,只 是 打开 和 关 掉 而 已 。 

译文 二 : 这 些 电子 硕 件 在 计算 机 中 起 开关 作用 ,只 是 开 开 关 关 而已。 

(2) And soon over the whole surface of the marsh, a great cloud of birds hung 
screaming and circling in the air. 

译文 一 : 很 快 就 有 一 块 马 云 似 的 一 大 群 野 乌 在 沼泽 上 空 惊 叫 着 ,盘旋 看 。 

译文 二 : 很 快 就 有 黑 压 压 的 一 大 群 野 乌 在 沼泽 地 上 空 尺 叫 着 ,盘旋 着。 

英语 的 alliteration( 头 章 ) 是 英语 的 骄 做 ,是 喘 语 获得 首 章 美的 台 柱 ,而 汉语 的 合 音 词 
则 是 男 一 道 更 加 绚丽 的 音韵 风景 。 译 文 一 与 译文 二 相 比 ,不 难 发 现 译文 二 因 使 用 了 汉语 
表达 的 登 音 词 而 天 关上 口 ,其 音韵 美 义 为 意境 的 营造 推波助澜 ,而 译文 一 并 非 误 译 ,但 读 
来 逊色 。 过 到 科技 汉 瑞 翻译 时 , 译 者 应 该 在 准确 翻译 的 基础 上 积极 运用 头 章 ,使 得 译文 在 
形式 上 更 加 紧 竣 。 

(3) 搜集 资料 加 以 论证 ,提出 理论 加 以 检验 ,然后 归纳 整理 研究 成 果 一 一 这 就 是 科学 
工作 的 全 部 内 容 。 

VÉ X; Gathering facts, conforming them, suggesting theories, testing them, and 
organizing findings — this is all the work of science. (词尾 -s,-em A PETI] ) 
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(4) 脱发 可 能 由 药物 .疾病 和 食物 引起 。 
译文 : Hair loss can be triggered by drug, disease and diet. ( 词 头 d- 形 成 视觉 押韵 效 
果 , 读 起 来 也 度 天 上 口 ) 


3. 结构 修辞 


ZF f SEE HI AY HR AE EER A repetition (反复 ) , catchword repetition ( 联 珠 )、 
chiasmus( |=] X ) , parallelism( 排比 ) ,antithesis( 5 XJ ) „rhetoric question( 设 问 ) 和 anticlimax 
( 突 降 ) 等。 下 面 以 排比 为 例 介 绍 结构 修辞 。 

排比 是 用 两 个 或 两 个 以 上 结构 相同 或 形似 的 句子 或 句子 成 分 表示 相近 或 相关 的 内 
容 , 有 反复 强调 菏 个 观点 ,使 人 留 下 深刻 印象 。 排 比 读 起 来 音韵 悠 扬 , 层 层 递 进 ,具有 流畅 的 
美 。 译 文 语言 应 力求 概念 准确 ,活泼 生动 ,行文 严 意 流畅 。 如 . 

(1) The Internet is also fun. You can write to old friends. Or check out their web 
pages. Enjoy web based soap operas. Laugh at online parodies and jokes. Join in a live Net 
Event. Chat with other Internet surfers. Pick a fake stock portfolio--- 

译文 : 因特网 也 很 好 玩 。 你 可 以 给 老 朋友 写 信 ,或 查看 他 们 的 网 页 ;欣赏 网 上 的 电视 
连续 剧 ; 网 上 还 有 模仿 的 滑 稿 剧 和 笑话 让 你 开心 ;你 可 以 参与 实况 网 络 动态 节目 ;与 别 的 
因特网 冲浪 者 聊天 ;模拟 跟 踊 股票 价 …… (原文 的 排比 由 一 连 串 短 句 组 成 ,译文 条 理 清 
晰 \ 语 势 如 滩 )。 

(2) It is the same old story of not being grateful for what we have until we lose it, of 
not being conscious of health until we are ill. 

译文 : 还 是 那 句 老话 ,失去 方 知 难得 , 病 后 倍 思 健康 (原文 排比 包含 两 个 of not 
being... 结 构 ,译文 妮 九 叙 来 , 层 层 递 进 ) 。 

(3) Manufacturing processes may be classified as unit production with small quantities 
being made and mass production with large numbers of identical parts being produced. 

译文 : 制造 方法 可 分 为 单 件 生产 和 批量 生产 。 单 件 生产 是 指 小 批量 的 生产 。 批 量 生 
产 是 指 生产 大 量 相 同 的 部 件 ( 由 于 汉 诸 重 意 合 , 汉 语句 子 间 的 关系 主要 由 意思 本 号 连 接 ， 
很 少 借 助 连词 或 介词 ;而 英语 重 形 合 , 句 子 之 间 的 结构 比较 严密 ,介词 和 连词 (特别 是 连 
词 ) 使 用 很 多 ,句子 的 各 个 组 成 成 分 和 句子 与 句子 之 间 的 关系 明确 , 主 次 清楚 。 因 此 , 汉 
详 时 不 能 全 盘 照搬 原文 的 句子 结构 ,而 应 按照 汉语 多 用 得 句 的 习惯 ,采用 先 总 后 分 ,讲究 
对 称 .排比 的 原则 ,达到 整齐 美的 效果 ) 。 

(4) Associated with limit loads is the proof factor, which is selected to ensure that if a 
limit load is applied to a structure the result will not be detrimental to the functioning of the 
aircraft, and the ultimate factor, which is intended to provide for the possibility of variations 
in structural strength. 

译文 : 与 极限 荷载 有 关 的 是 保险 系数 和 终 级 系数 。 选 合适 的 保险 系数 保证 即使 极限 
何 载 加 在 飞机 上 ,飞行 也 不 会 受到 损害 ;终极 系数 则 是 用 来 预防 结构 强度 可 能 发 生 的 变化 
(译文 采用 排比 结构 ,用 了 由 非 限制 性 定语 从 名 引导 的 两 个 相同 结构 ,显得 对 称 整齐 、 和 
谐 优美 ,给 人 一 气 呵 成 之 感 ) 。 
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B.4 计算 机 专业 科技 论文 的 结构 特点 


1. 科技 论文 的 结构 


一 篇 完整 规范 的 学 术 论 文 结 构 包 括 Title, Abstract , Introduction , Method , Result , 
Discussion , Conclusion 和 Reference 八 项 内 容 , 这 是 必 不 可 少 的 ,其 他 内 容 则 根据 具体 需要 
而 定 , 如 Keywords (关键 词 ) , Table of contents ( 目录 )、Nomenclature (术语 表 )、 
Acknowledgement( 致谢 ) , Appendix ( 附录 ) , Notes( 2E TE) 。 


2. 科技 论文 标题 的 与 法 


学 术 文 草 的 标题 主要 有 三 种 结构 ;名 词性 词组 (包括 动 名 词 ) .介词 词组 、 名词/ 名 词 
词组 + 介词 词组 。 在 人 文 社会 科学 领域 ,有 时 也 用 一 个 疑问 句 作 标题 ,但 一 般 不 用 陈述 名 
或 动词 词组 作 标 题 。 

1) 名 词性 词组 

名 词性 词组 由 名 词 及 其 修饰 语 构 成 。 名 词 的 修饰 语 可 以 是 形容 词 .介词 短语 ,有 时 也 
可 以 是 另 一 个 名 词 。 名 词 修 饰 名 词 时 ,往往 可 以 缩短 标题 的 长 度 。 以 下 各 标题 分 别 由 两 
个 名 词 词 组 构成 。 例 如 : 

latent demand and the browsing shopper (名 词 词组 + 名 词 词组 ) 

cost and productivity ( 名词 + 名 词 ) 

2) 介词 词组 

介词 词组 由 介词 十 名 词 或 名 词 词组 构成 。 如 果 整 个 标题 就 是 一 个 介词 词组 ,一 般 这 
个 介词 是 on ,意思 是 “对 …… 的 研究 ”。 例 如 . 

from knowledge engineering to knowledge management (介词 词组 + 介词 词组 ) 

on the correlation between working memory capacity and performance on 
intelligence tests 

3) 名 词 / 名 词 词 组 + 介词 词组 

这 是 标题 中 用 得 最 多 的 结构 。 例 如 : 

simulation of controlled financial statements (和 名词 + 介词 词组 ) 

the impact of internal marketing activities on external marketing outcomes ( 名词 + 介词 
词组 + 介词 词组 ) 

diversity in the future work force (名 词 + 介词 词组 ) 

models of sustaining human and natural development ( 名词 + 介词 词组 ) 

标题 中 的 介词 词组 一 般 用 来 修饰 名 词 或 名 词 词组 ,从 而 限定 某 人 研究 课题 的 范围 。 这 
种 结构 与 中 文 的 “的 " 字 结 构 相 似 , 区别 是 中 文 标 题 中 是 修饰 语 在 前 ,中 心 词 在 后 。 瑞 文 
正好 相反 ,名词 在 前 ,而 作为 修饰 语 的 介词 短语 在 后 。 例 如 : 

progress on fuel cell and its materials ( 燃料 电池 及 其 材料 进展 ) 
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4) 其 他 形式 

对 于 值得 争议 的 问题 ,偶尔 可 用 疑问 句 作 为 论文 的 标题 ,以 点 明 整 个 论文 讨论 的 焦 
点 。 例 如 : 

Is B2B e-commerce ready for prime time? 

Can ERP Meet Your eBusiness Needs? 

有 的 标题 由 两 部 分 组 成 ,用 冒号 (:) 隐 开 。 一 般 来 说 ,冒号 前 面 一 部 分 是 妍 究 的 对 


象 内容 或 诛 题 ,比较 笼统 ,冒号 后 面具 体 说 明 研 究 重点 或 研究 方法 。 这 种 结构 可 再 分 为 
三 种 模式 。 


模式 1 MRA: AAA. ld: 

Microelectronic Assembly and Packaging Technology : Barriers and Needs 
The Computer Dictionary Project; an update 

模式 2 WR: TIE / TEN. DU: 

B2B E-Commerce: A Quick Introduction 

The Use of Technology in Higher Education Programs; a National Survey 
模式 3 MAA LAR DU. 


Caring about connections; gender and computing 
3. 英文 摘要 的 与 作 技巧 


英文 摘要 (Abstract) 的 写作 应 用 很 广 。 论 文摘 要 是 全 文 的 精华 ,是 对 一 项 科学 研究 
工作 的 总 结 , 是 对 研究 目的 方法 和 研究 结果 的 概括 。 

1) 摘要 的 种 类 与 特点 

摘要 主要 有 以 下 四 种 。 

第 一 种 是 随同 论文 一 起 在 学 术 刊 物 上 发 表 的 摘要 。 这 种 摘要 置 于 主体 部 分 前 ,目的 
是 让 读者 首先 了 解 一 下 论文 的 内 容 , 以 便 决 定 是否 阅 读 全 文 。 一 般 来 说 ,这 种 摘要 在 全 文 
完成 之 后 写 。 字 数 限制 为 100 ~150 字 。 内 容 包 括 人 研究 目的 、 人 研究 方法 、 人 研究 结果 和 主要 
结论 。 

第 二 种 是 学 术 会 议论 文摘 要 。 会 议论 文摘 要 往往 在 会 议 召 开 之 前 几 个 月 撰写 ,目的 
是 交 给 会 议论 文 评审 委员 会 评阅 ,从 而 决定 是 否 能 够 录用 。 所 以 ,这 种 摘要 比 第 一 种 略为 
详细 ,字数 为 200 -300 字 。 在 会 议论 文摘 要 的 开头 有 必要 简单 介绍 一 下 研究 课题 的 意 
义 . 目 的 .宗旨 等 。 如 果 在 写 摘要 时 研究 工作 尚未 完成 ,全 部 研究 结果 还 未 得 到 ,就 应 在 方 
法 目的、 军 引 、 假 设 等 方面 多 花 笔墨 。 

第 三 种 为 学 位 论文 摘要 。 学 士 硕士 和 博士 论文 摘要 一 般 都 要 求 用 中 .英文 两 种 语言 
写 。 学 位 论文 摘要 一 般 在 400 字 左 右 , 根 据 需 要 可 以 分 为 几 个 段落 。 内 容 一 般 包 括 研究 
ou .意义 .主旨 和 目的 ;基本 理论 依据 .基本 假设 ;研究 方法 ;研究 结果 ;主要 创新 点 ;简短 
讨论 。 不 同 级 别 的 学 位 论文 摘要 ,要 突出 不 同 程度 的 创新 之 处 ,指出 有 何 新 的 观点 、 见解 
或 解决 问题 的 新 方法 。 

第 四 种 是 脱离 原文 而 独立 发 表 的 摘要 。 这 种 摘要 更 应 该 具有 独立 性 、 目 含 性 、 完 整 
性 。 读 者 无 须 阅 读 全 文 , 便 可 以 了 解 全 文 的 主要 内 容 。 
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2) 摘要 的 内 容 与 结构 

RA A LE : 

FAY ( objectives, purposes ) : 145 Wt FE Fr x us Fl A AE BS APE EY [8 RS DK — [n] 
题 的 重要 性 和 意义 。 

方法 (methods and materials) :包括 材料 手段 和 过 程 。 

结果 与 简短 讨论 (results and discussions) :包括 数据 与 分 析 。 

结论 (conclusions) :主要 结论 ,人 研究 的 价值 和 意义 等 。 

概括 地 说 ,摘要 必须 回答 “人 研究 什么 “怎么 研究 “得 到 了 什么 结果 ”“ 结 果 说 明了 什 
么 ”等 问题 。 无 论 哪 种 摘要 ,语言 特点 和 文体 风格 都 相同 。 首 先 必须 符合 格式 规范 。 语 
言 必须 规范 通顺 ,准确 得 体 , 用 词 要 确切 .恰如其分 ,而 且 要 避免 非 通用 的 符号 LAIT E 
偏 词 。 男 外 ,摘要 的 语气 要 客观 ,不 要 做 出 言 过 其 实 的 结论 。 

3) 摘要 的 英文 写作 风格 

炎 文 摘要 写作 要 求 句 子 完 整 清晰 、 人 简洁 ;力求 用 简单 句 。 为 避免 单调 ,可 改变 句子 的 
长 度 和 句子 的 结构 。 用 过 去 时 态 描 述 作 者 的 工作 ,因为 是 过 去 所 做 的 ,但 是 用 现在 时 态 描 
述 所 做 的 结论 。 

摘要 中 避免 使 用 动词 的 名 词 形 式 。 如 : 

iE: “Thickness of plastic sheet was measured" 

IX ; "^ measurement of thickness of plastic sheet was made” 

1E WA fs H3 se ti), BE Jr oh Be E] , ,也 应 避免 整 脚 地 省 略 冠 词 。 如 : 

iE: ^ Pressure is a function of the temperature” 

IX" The pressure is a function of the temperature" ; 

fidi HS BS . 连 串 的 形容 词 ,名词 或 形容 词 加 名 词 修 饰 名 词 。 为 打破 这 种 状态 ,可 使 用 
介词 短语 ,或 用 连 字符 连接 名 词 词组 中 的 名 词 ,形成 修饰 单元 。 例 如 : 

应 写 为 “The chlorine-containing propylene-based polymer of high melt index" , 

而 不 写 为 “The chlorine containing high melt index-propylene based polymer" 

使 用 短 的 fg PLE SR S B), AAR SE fH] EATS Lf Af Hd 
被 动 语 态 。“A exceeds B” 读 起 来 要 好 于 “B is exceeded by A”。 使 用 主动 语 态 还 有 助 于 
避免 过 多 地 使 用 类 似 于 is was .are 和 were 这 样 的 弱 动 词 。 

构成 句子 时 ,动词 应 靠近 主语 。 避 免 形 如 以 下 的 句子 : 

“The decolorization in solutions of the pigment in dioxane, which were exposed to 10 hr 


, 


of UV irradiation, was no longer irreversible. ' 

改进 的 句子 应 当 是 : 

" When the pigment was dissolved in dioxane, decolorization was irreversible, after 10 
hr of UV irradiation. " 

避免 使 用 既 不 说 明 问 题 ,又 没有 任何 含义 的 短语 。 例 如 .;“ specially designed or 
formulated" “The author discusses” “The author studied” MWE . 
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4. IEX. 
学 术 论 文 的 正文 一 般 包 括 Method , Result, Discussion 三 部 分 。 这 三 部 分 主要 描述 人 研 


究 课 题 的 具体 内 容 方法 ,人 研究 过 程 中 所 使 用 的 设备 、 仪 需 、 和 条件, 并 如 实 公 布 有 关 数 据 和 
研究 结果 等 。Conclusion 是 对 全 文 内 容 或 有 关 人 研究 课题 进行 的 总 体 性 讨论 。 它 具有 严密 
的 科学 性 和 客观 性 ,反映 一 个 研究 课题 的 价值 ,同时 提出 以 后 的 研究 方向 。 


为 了 带 助 说 明 论 据 、 事 实 , 正 文中 经 常 使 用 各 种 图 表 。 最 第 用 的 是 附 图 ( Figure ) MK 


( Table) ,此 外 还 有 图 解 或 简 图 (Diagram ) .曲线 图 或 流程 图 (Graph) ,视图 ( View ) , iil Tig 
图 (Profile) KIE ( Pattern) 等 。 在 文中 提 到 时 ,通常 的 表达 法 为 


如 图 4 所 示 As (is) shown in Fig. 4, 
如 表 1 所 示 As (is) shown in Tab. 1, 


5. 结论 


正文 最 后 应 有 结论 (Conclusions ) 或 建议 ( Suggestions) 。 

(1) 关于 结论 ,可 用 如 下 表达 方式 : 

(D The following conclusions can be drawn from …( H- 可 得 出 如 下 结论 ) 

(2) It can be concluded that …( 可 以 得 出 结论 …… ) 

(3) We may conclude that… 或 We come to the conclusion that --- (我 们 得 出 如 下 结 


(4) It is generally accepted (believed, held, acknowledged) that--- ( 一般 认为 .…… ) (用 


于 表示 肯定 的 结论 ) 


(5) We think (consider, believe, feel) that…( 我 们 认为 ……… ) (用 于 表示 留 有 商量 余 


地 的 结论 ) 


(2) 关于 建议 ,可 用 如 下 表达 方式 。 

(D It is advantageous to ( do) 

(2) It should be realized (emphasized, stressed, noted, pointed out ) that --- 
(3) It is suggested ( proposed, recommended, desirable) that --- 

(4) It would be better ( helpful, advisable) that--- 


6. 结尾 部 分 


1) 致谢 
为 了 对 曾 给 予 支持 与 帮助 或 关心 的 人 表示 感谢 ,在 论文 之 后 ,作者 通常 对 有 关 人 员 致 


以 简短 的 谢 词 ,可 用 如 下 方式 : 


I am thankful to sb. for sth. 

I am grateful to sb. for sth. 

I am deeply indebted to sb. for sth. 
I would like to thank sb. for sth. 
Thanks are due to sb. for sth. 


: 170- 


The author wishes to express his sincere appreciation to sb. for sth. 

The author wishes to acknowledge sb. 

The author wishes to express his gratitude for sth. 

2) 注释 

注释 有 两 种 方式 : 一 种 为 脚注 ,即将 注释 放 在 出 现 的 当 页 的 部 ;为 一 种 是 将 全 文 注释 
集中 在 结尾 部 分 。 两 种 注释 位 置 不 同 , 方 法 一 样 。 注 释 内 容 包 括 : 

(D 引文 出 处 。 注 释 方 式 参 见 “ 参 考 文献 ”。 

D 对 引文 的 说 明 , 如 作者 的 见解 .解释 。 

(3) 文中 提 到 的 人 的 号 份 ,依次 为 职称 或 职务 单位。 如 : 

Professor, Dean of Dept:…. University ( 教授,…… 大 学 ……… 系 主 任 ) 

Chairman, … Company, USA (美国 …… 公司 董事 长 ) 

D 本 论文 是 否 曾 发 表 过 。 

3) 参考 文献 

在 论文 的 最 后 ,应 列 出 论文 所 参考 过 的 主要 论著 ,目的 是 表示 对 别人 成 果 的 尊重 或 表 
示 本 论文 的 科学 根据 ,同时 也 便于 读者 查阅 。 参 考 文献 的 列 法 如 下 : 

如 果 是 书籍 ,应 依次 写 出 作者 、 书 名 、 出 版 社 名 称 、 出 版 年 代 、 页 数 。 如 : 

Dailey, C. L. and Wood, F. C. , Computation curves for compressible Fluid Problems, 
John Wiley & Sons, Inc. New York, 1949, pp. 37-39 

如 果 是 论文 ,应 依次 写 出 作者 ,论文 题目 .杂志 名 称 , 卷 次 .期 次 .出 版 年 份 .页 数 。 如 : 

Marrish Joseph G. , Turbulence Modeling for Computational Aerodynamics, A/AA J. 
Vol-21 , No. 7, 1983, PP. 941-955 

如 果 是 会 议 的 会 刊 或 论文 集 , 则 应 指出 会 议 举 行 的 时 间 、 地 点 。 如 : 

Proceedings of the Sixth International Conference on Fracture Dec. 4-10, 1984, New 
Delhi, India 

如 果 作 者 不 止 一 人 ,可 列 出 第 一 作者 ,其 后 加 上 et al, 4; Wagner, R.S. etal, …. 
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附录 C ”常见 计算 机 美语 缩写 
A 


3G,4G,5G 3",4^".5" Generation, 第 三 代 , 第 四 代 , 第 五 代 移动 通信 业务 


A/D 
AB 
AC 


ADCCP 


ADO 
ADP 
ADPCM 
ADSL 


ADTS 
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Analog/ Digital ,模拟 /数字 

Address Bus ,地 址 总 线 

Alternating Current ,交流 电 

Audio Coding-3 (Dolby Digital AC-3) ,由 Dolby 实验 室 制定 的 一 个 音 
Advanced Configuration and Power Interface, 高 级 配置 和 电源 管理 界面 
Accounting Control System, , 记 账 管理 系统 (Univac 公司 ) 

Adaptive Computer System, 自 适应 计算 机 系统 

Advanced Connectivity System , 先进 布线 系统 

Alternating Current Synchronous , 交流 同步 

Automatic Coding System , 自动 编码 系统 

Advanced Data Communication Control Procedure, 高 级 数据 通信 控制 
规程 

ActiveX Data Objects ,Microsoft 公司 的 一 种 新 的 数据 访问 模型 
Automatic Data Processing , 自动 数据 处 理 

Adaptive Differential Pulse Code Modulation, 自 适 应 差分 脉冲 编码 调制 
Asymmetrical Digital Subscriber Loop , 非 对 称 数字 用 户 环线 

Analog to Digital Simulation Language , 模 - 数 模拟 语言 

Asymmetric Digital Subscriber Line ,异步 数字 用 户 线 

Audio Data Transport Stream ,音频 数据 传输 流 

Automated Data and Telecommunications Service, 自动 数据 和 远程 通信 
服务 

Accelerated Graphics Port ,加速 图 形 接口 

Artificial Intelligence, 人工 智能 

Asynchronous Line Interface ,异步 线路 接口 

Automatic Location Identification , 自动 位 置 识 别 

Alternate Key ,备用 键 

Automatic Line Test ,线路 自动 测试 

Arithmetic and Logic Unit, 算术 与 逻辑 部 件 ( 运 复 器 ,算术 逻辑 单位 ) 
Advanced Micro Device, ( 美国 ) AMD 公司 (主要 生产 半导体 及 芯片 ) 
Air Movement Data, 空气 运动 数据 


AMI 


AMR 


AN 
ANSI 
AOL 


APC 


API 
APM 


APPC 


ARP 
ARPA 
ARX 
ASCII 


ASP 
ATL 


Analog Memory Device , 7 3 # fid 28 (t 

Associative Memory Data, 相 联 存储 数据 

Associative Memory Device , 相 联 存储 器 件 

Access Method Interface , 存 取 方法 接口 

Alternate Mark Inversion , 传 号 交替 变换 

American Micro system ,美国 微 计算 机 系统 

Audio/Modem Riser ,声音 .调制解调器 揪 卡 

Arithmetic Mask Register ,运算 屏蔽 寄存 器 

Automatic Message Recording, 自动 信息 记录 

Automatic Message Registering, 自动 信息 挂号 (登记 ) 
Access Network , 接 入 网 

American National Standards Institute , 美 家 标准 协会 
American On-Line ,美国 在 线 服 务 公司 

All On-Line ,全 部 联机 

Adaptive Predictive Coding, 自 适 应 预测 编码 (法 ,技术 ) 
Angular Position Counter, 角 位 置 计 数 器 

Associative Processor Controller , 相 联 处 理 机 控制 器 
Automatic Peripheral Control, 自动 外 ( 围 ) 设 ( 备 ) 控 制 (器 ) 
Automatic Program Control , 自动 程序 控制 

Application Program Interface ,应 用 程序 接口 

Advanced Power Management ,高 级 电源 管理 

Automatic Predictive Maintenance , 自动 预测 性 维护 
Automatic Programming Machine , 自动 程序 设计 机 
Advanced Program to Program Communications ,先进 的 程序 间 通 信 技 术 
(方法 ,( 子 ) 系 统 ,协议 ,程序 ) 

Automatic Power Plant Checker ,电源 设备 自动 检验 器 
Address Resolution Protocol ,地 址 解析 协议 

Advanced Research Project Agency ,高 级 研究 计划 局 
Automatic Retransmission eXchange , 自动 重 发 交换 机 
American Standard Code for Information Interchange ,美国 信息 交换 标准 


代码 
Active Server Pages, 动 态 服务 器 页 面 
Active Task List, 有 效 任务 表 


Active Time List, 有 效 时 间 表 
Analog Transmission Line ,模拟 传输 线路 
ActiveX Template Library , ActiveX 模板 库 
Application Terminal Language, ,应 用 终端 语言 
Artificial Transmission Line , 仿真 传输 线 
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ATM 


ATX 


AVGA 


AVI 


BASIC 


BBL 
BBS 
BCD 
BDE 
BGA 
BGP 
BIOS 


BLOBs 


BNC 
BO 
BPL 
Bps 
bps 
BRI 
BTB 


CA 
CAD 
CAE 
CAI 
CAM 
CAPP 
CASE 
CASL 
CAT 
CAX 
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Automatic TeLling, 自动 出 纳 

Asynchronous Transfer Mode ,异步 传输 模式 

Automatic Teller Machine, 自动 取款 [ 出 纳 ] 机 

Auxiliary Tape Memory , 辅助 磁带 存储 器 

Advanced Technology eXtended , 一 种 新 的 PC 主板 架构 规范 
Accelerated Video Graphics Array ,加 速 的 视频 图 形 阵 列 显 示 卡 
Audio Video Interlaced , Video for Windows 的 多 媒体 文件 格式 


b 


Beginner's All-purpose Symbolic Instruction Code , 初学 者 通用 符号 指 
令 码 

Be Back Later , 稍 候 便 回 

Bulletin Board System ,电子 公告 栏 系统 
Binary-Coded Decimal , 二- 十进制 码 

Borland Database Engine ,Borland 的 数据 库 引 擎 
Ball Grid Array , 球 栅 阵列 (组 件 ) 

Border Gateway Protocol ,边界 网 关 协 议 

Basic Input/Output System , 基本 输入 输出 系统 
Binary Large Objects ,很 大 的 二 进 制 数据 块 
Bayonet Nut Connector, 同 轴 电线 接 插 件 

Back Orifice ,后 门 (一 种 墨客 程序 ) 

Broadband over Power Lines ,电力 线 宽带 

Bytes Per Second ,比特 每 秒 

bits per second ,位 每 秒 

Basic Rate Interface , X Aik 5E dz: U 

Branch Target Buffer, 分支 目标 缓冲 器 


C 


Certificate Authority ,数字 证 书 认 证 中 心 

Computer Aided Design , 计算 机 辅助 设计 

Computer Aided Engineering , 计算 机 辅助 工程 

Computer Aided Instruction ,计算 机 辅助 教学 

Computer Aided Manufacturing , 计算 机 辅助 制造 

Computer Aided Process Planning , 计算 机 辅助 工艺 规划 
Computer Aided Software Engineering , 计算 机 辅助 软件 工程 
Computer Assembly System Language ,计算 机 汇编 系统 语言 
Computer Aided Test, 计算 机 辅助 测试 

Community Automatic eXchange ,公用 自动 交换 (机 ) 


CB 
CBD 
CBE 
CCIT 


CCW 


CD-DA 
CD-I 
CDMA 
CD-R 
CD-ROM 
CD-RW 
CE 


CEO 


CERNet 


CES 


CGA 
CGI 


Control Bus , 控制 总 线 

Central Business District, 中 央 商 务 区 
Computer-Based Education, 计算 机 辅助 教育 
Consultative Committee of International Telegraph and Telephone, 国际 电 
报 电话 咨询 委员 会 

Channel Command Word ,通道 命令 字 

Channel Control Word , 通道 控制 字 

China Computer World , 计算 机 世界 (中 国 ) 

Counter Clock Wise , 逆 时 针 方 向 (的 ) 

Compact Disc Digital Audio, ,数字 音频 光盘 

Compact Disc Interactive , X Z 3X, CD 

Code Division Multiple Access , 码 分 多 路 访问 (通信 ) 
Compact Disc Recordable ,一 次 性 可 写 入 光盘 
Compact Disc Read-Only Memory ,光盘 只 读 存 储 器 
CD-ReWritable, *| € & #5 Ht di 

Call Entry ,调用 入 口 

Channel End ,通道 传送 结束 (通道 末端 ) 

Chip Enable ,芯片 启动 

Circular Error , 循环 误差 

Clear Entry ,清除 输入 

Common Emitter , 共 射 极 

Communication Equipment ,通信 设备 

Computer Engineer , 计算 机 工程 师 

Chief Executive Officer , 14.47 Š 3& 

Chip Enable Output, 芯片 启用 (使 能 ) 输 出 

China Education and Research Computer Network, 中 国教 育 和 科研 计算 
机 网 络 

Communication Engineering Standard ,通信 工程 标准 (日 本 ) 
Computer Education System ,计算 机 教育 系统 
Consumer Electronics Show ,家 用 电子 产品 展览 
Color Graphics Adapter ,彩色 图 形 适 配器 

Common Gateway Interface ,公共 网 关 接 口 

Computer Graphics Interface , 计算 机 图 形 接口 


CHINAMDN China Mobile Directory Number ,公用 移动 数据 通信 网 


CHS 
CIA 


Cylinders, Heads, Sectors , 柱 面 数 、 磁 头 数 、 每 柱 面 属 区 数 
Communication Interface Adaptor ,通信 接口 适配器 
Communication Interrupt Analysis ,通信 中 断 分 析 
Computer Industry Association , 计算 机 工业 协会 
. 175. 


CIMS 
CIP 


CISC 
CIT 
CIX 
CJK 
CMI 
CMM 


CMOS 
CNN 


CNNIC 
COFF 
COM 


COMDEX 
CORBA 


CPU 
CRC 
CREF 
CRM 
CRT 
CDMA 
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Computers Interface Adaptor ,计算 机 接口 适配器 

the Central Intelligence Agency of the U. S. ,中 央 情 报 局 
Computer-Integrated Manufacturing System, 计算 机 集成 制造 系统 
Catalog(u)ing In Publication, fi 4% E 2k ,出 版 过 程 中 编目 
Commercial Instruction Processor , 商用 指令 处 理 机 

Communication Interrupt Program ,通信 中 断 程 序 

Console Interface Program , 控制 台 接 口 程序 

Complex Instruction Set Computer ,复杂 指令 集 ( 系 统 ) 计 算 机 
Cambridge Information Technology ,剑桥 信息 技术 

Commercial Internet Exchange ,商业 Internet 交换 中 心 
China-Japan-Korea , 中 日 韩 

Computer-Management Instruction , 计算 机 管理 教学 

Commission for Maritime Meteorology ,海洋 气象 委员 会 (联合 国 ) 
Computerized Modular Monitoring , 计算 机 化 组 件 监 控 

Controllable Memory Module ,可 控 存 储 组 件 

Complementary Metal Oxide Semiconductor ,互补 金属 氧化 物 半 导体 
Cable News Network ,美国 有 线 新 闻 网 络 ( 以 提供 即时 电视 新 闻 报 道 而 
HED) 

China Internet Network Information Center, 中 国 互联 网 络 信息 中 心 
Common Object File Format, 公 用 目标 ( 对象) 文件 格式 
Component Object Model ,组 件 对 象 模型 

Commercial organizations , | 域 ] 商 业 组 织 , 公 司 

Check Operations Manual , 检验 操作 手册 

COMmand , 命令 

COMmon compiler ,公共 编译 程序 

COMmon function (Logic Block) , AJ 34 8E ( 3£ E 3) ;公共 操作 
COMmunications ,通信 

Commutator ,整流 子 , 换 向 器 , 转 接 器 

COMpiler , 编译 

Computer Distributor Exph, 计算 机 分 销 商 展 览 

Common Object Request Broker Architecture ,公用 对 象 请 求 代理 (调度 ) 
程序 体系 结构 

Central Processing Unit, 中 央 处 理 器 

Cyclic Redundancy Check ,循环 元 余 校 验 法 [ 循环 元 余 核 对 ] 

Cross REFerence , 相互 参照 

Customer Relationship Management, 客户 关系 管理 

Cathode-Ray Tube, , 阴极 射线 管 

Coding Division Multiplexing Access , 码 分 多 路 复 用 ,又 称 码 分 多 址 


CSMA/CD Carrier Sense Multiple Access/Collision Detect ,载波 监听 多 路 访问 /冲突 
检测 

CSP Communication Scanner Processor ,通信 扫描 处 理 器 
Coder Sequential Pulse , 编码 器 顺序 脉冲 
Commercial Subroutine Package , 商用 子 例 行 程序 包 
Completely-Self-Protected ,全 自 保护 
Control Setting Panel, 控 制 参 数 设 定 板 
Control Signal Processor ,控制 信号 处 理 机 

CSP/AD Cross System Product/ Application Development, 跨 系 统 ( 程 序 ) 产 品 / 应 


用 软件 开发 程序 

CSP/AE Cross System Product/ Application Execution , 跨 系 统 ( 程 序 ) 产 品 / 应 用 
软件 执行 程序 

CSS Communication SubSystem ,通信 子 系统 


Common Support System ,公用 支援 系统 

Computer Scheduling System , 计算 机 调度 系统 

Computer SubSystem , 计算 机 子 系统 

Computer System Simulation , 计算 机 系统 模拟 

Contact Start Stop ,接触 起 停 
CSTNet China Science and Technology Network, , 中 国 科学 技术 网 
CT Cable TV ,有 线 电视 


CTEC ( Microsoft) Certified Technical Education Center , Microsoft 认证 高 级 技 
术 教育 中 心 

CTO Chief Technical Officer ,首席 技术 执行 官 

CUA Channel and Unit Address ,通道 和 单元 地 址 


Common User Access ,公共 用 户 访 问 ( 程 序 ) 


D 

DAC Digital-to-Analog Converter , 数 模 转换 器 
DAO Data Access Object ,数据 访问 对 象 
DB Data Base ,数据 库 

Data Bus ,数据 总 线 

Data Bank, # & ,数据 库 , 资 料 库 

Data Bit ,数据 位 

Dead Band, ## #7 7t [X 

DeciBel , 4^ Jl 
DBA DataBase Administrator ,数据库 管 理 员 
DBCC DataBase Consistency Checker ,数据 库 一 致 性 检查 器 
DBDD Data Base Design Description ,数据 库 设计 描述 


*。1//。 


DBMS 


DBS 
DC 


DCB 
DCC 
DCD 
DCE 
DCL 


DCOM 


OLE 
DCR 
DCT 
DD 


DEA 
DDA 


DDB 


DDC 
DDD 


DDE 
DDL 
DDN 
DDR 


DDRRAM 


DDS 
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Data Base Management System ,数据 库 管理 系统 

Data Base System ,数据 库 系 统 

Direct Current , 直流 电 

Device Context , 设备 描述 表 

Device Controller Block ,设备 控制 块 

Direct Cable Connection , 直接 电缆 连接 

Dynamic Content Delivery ,数据 载波 检测 

Data Communication Equipment ,数据 通信 设备 

Data Control Language ,数据 控制 语言 

Distributed Component Object Model , 分 布 式 组 件 对 象 模型 
Data Center Operations Management ,数据 中 心 运 行 管理 
Object Linking and Embedding ,对 象 连 接 与 葡 入 。 以 前 称 为 网 络 OLE 
Document Change Request, 文档 更 改 请 求 

Discrete Cosine Transform , 离散 余弦 变换 

Data Dictionary , 数据 字典 

Detailed Design Phase ,详细 设计 阶段 

Display Director, 同 屏 显示 

Data Encryption Algorithm ,数据 加 密 算法 

Data Decoder Assembly ,数据 译 码 器 组 件 

Data Display Alarm ,数据 显示 报警 (装置 ) 

Demand Deposit Accounting ,活期 存款 记 账 (程序 ,软件 ) 
Digital Differential Analyzer ,数字 微分 分 析 仪 

Digital Display Alarm ,数字 显示 报警 

Data Display Board ,数据 显示 板 

Descriptive Data Base, 描述 数据 库 

Design Data Book ,设计 数据 手册 

Device Descriptor Block , 设备 描述 块 

Digital Data Buffer ,数字 数据 缓冲 器 

Distributed Data Base ,分布 式 数据 库 

Display Data Channel, 显示 数据 通道 

Domestic Direct Dial, 国内 长 途 直 拨 

Detailed Design Document ,详细 设计 文档 

Dynamic Data Exchange ,动态 数据 交换 
Data-Definition-Language ,数据 定义 语言 

Digital Data Net ,数字 数据 网 

Detailed Design Review ,详细 设计 评审 

Double Data Rate , 一 种 随机 存 取 存储 器 

Data Dictionary System ,数据 词典 系统 


Data Display System ,数据 显示 系统 

Data Distribution System ,数据 分 配 系 统 

Data phone Digital System ,数据 电话 数字 系统 

Dataphone Digital Service( AT&T ) ,数据 电话 数字 业务 (美国 电话 电报 


公司 ) 

Decision Support System ,决策 支持 系统 
DDX Digital Data eXchange ,数字 数据 交换 

Dialog Data eXchange ,对 话 框 数据 交换 
DFT Diagnostic Function Test ,功能 诊断 测试 程序 


Diagnostic Function Tester ,诊断 功能 测试 程序 
Discrete Fourier Transform , E $0 (&. E "+ 7k J 
Drive Fitness Tesr ,驱动 器 性 能 检测 

DHTML Dynamic HTML, zj & HTML 


DID Data Item Description ,数据 项 描述 

DII Dynamic Invocation Interface ,动态 调用 接口 

DIME Dual Independent Map Encoding , 双 独 立地 图 编码 
DIMM Dual Inline Memory Module, SDRAM 内 存 条 

DIP Display Information Processor , 显示 信息 处 理 机 (程序 ) 


Distributed Information Processing ,分布 式 信息 处 理 (技术 ,方法 ) 
Draft International standard Proposal, ( ISO) 国际 标准 草案 
Dual In-line Package, X 7] (H) E dd AAR 
DirectX Direct eXtension, 微软 公司 对 硬件 编程 的 接口 , 包括 DirectDraw, 
DirectSound & 


DIS Digital Immune System ,数字 免疫 系统 

DIY Do It Yourself, 自己 动手 作 

DJ Disc Jockey, (广播 电台 ) 流 行 音 乐 播音 员 ,流行 音乐 节目 主持 人 
DLC Data Line Controller , 数据 传输 线 控 制 器 


Data Link Control, { SNA | 数据 链 路 控制 
Data Link Control field ,数据 链 路 控制 字段 
Digital Logic Circuit , # 7 2 $ 8 J& 


DLL Dynamic Link Library ,动态 链接 库 

DLS Downloadable Sound , 一 种 音色 库存 的 存放 方法 

DMA Direct Memory Access ,直接 存储 器 存 取 

DMI Desktop Management Interface , 果 式 管理 界面 
Direct Memory Interface , 直接 存储 器 接口 

DML Data Manipulation Language ,数据 操纵 语言 

DNS Domain Name System ,域名 系统 

DOC Data Output Clock ,数据 输出 时 钟 
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Display Operator Console, 显示 操作 控制 合 


DOM Document Object Model , 文档 对 象 模型 
DPI Data Pathing Inc. ,数据 通路 公司 
DPMI DOS Protect Modal Interface ,DOS 保护 模式 接口 
DPMS Display Power Manage System , 显示 器 电源 管理 
DPS Data Protection System ,数据 保护 系统 

Data Path Switch , 数据 通路 开关 


Data Processing Station ,数据 处 理 站 

Data Processing Subsystem ,数据 处 理子 系统 
Data Processing System ,数据 处 理 系 统 
Delayed Printer Simulator , 延 识 打印 机 模拟 器 
Desk Publishing System , 台式 出 版 系统 


DRAM Dynamic Random Access Memory ,动态 随机 存 取 存储 器 
DSL Data Set Label ,数据 集 标 号 


Data SubLanguage ,数据 子 语言 

Dialogue Specification Language ,对 话说 明 语言 
Digital Simulation Language ,数字 模拟 语言 
Direct Swift Link ,直接 快 连 链 路 


DSO Data Source Object ,数据 来 源 对 象 
DSP Digital Signal Processing ,数字 信号 处 理 
DST Drive Self Test ,驱动 器 自我 测试 
DTD Document Type Definition ,文件 类 型 定义 
DTS Data Transformation Services ,数据 转换 服务 
DVD Digital Visual Disc ,数字化 视频 光盘 

Digital Versatile Disc ,数字 万 能 光盘 
DVI DeVice Independent, 一 种 电子 文件 格式 

E 

EAX Environmental Audio Extension , 环境 音效 


Electronic Automatic eXchange ,电子 自动 交换 机 
EBCDIC Extended Binary-Coded Decimal Interchange Code ,扩展 的 二 -十 进 制 交 


换 码 
EC Electronic Commerce , 电子 商务 
ECC Error Correction Code , 24 44 #4 , 4 jX HAE 


Electron Coupling Control ,电子 神 合 控制 
Electronic Communication Center , 电子 通信 中 心 
Electronic Components Conference ,电子 元 件 会 议 
Electronic Control Circuit , 电子 控制 电路 
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Emergency Communi Cation ,应 急 通 信 


ECP Extended Capabilities Port ,扩展 并 行 口 

ECTS European Computer Trade Show ,欧洲 计算 机 交易 大 展 
EDI Electronic Data Interchange ,电子 数据 交换 

EDO Error Demodulator Output , 错误 解 调 输出 


EDORAM Extended Data Output RAM, 3 #27240 1B MALE EEA 
EEPROM Electrically Erasable Programmable Read-only , 电 可 擦 除 只 读 存 储 器 


EIA Electronic Industries Association , 电子 工业 协会 
EIDE Enhanced Intelligent Device Electronics ,增强 型 智能 设备 电子 接口 
EISA Extended( Extension) Industry Standard Architecture ,扩展 工业 标准 结构 
EMF Encrypted Magic Folders ,为 文件 夹 加 密 的 工具 软件 
EPA Environmental Protection Agency ,美国 环保 署 
Entry Point Address ,入 口 点 地 址 
EPP Enhanced Parallel Port , 增强 并 行 口 
ER Explicit Route, SNA 显 式 路 由 


Exponent Register , N F G #5 

Extension Register, 4 75 4 4$ 2 

External Register , 外 部 寄存 器 
Entity-Relationship Approach ,实体 -关系 图 


ERM Employee Relationship Management, 员工 关系 管理 
ERP Enterprise Resource Planning ,企业 资源 计划 
ESDI Enhanced Small Device Interface ,加 强 的 小 型 设备 接口 
ESS Electronic Switching System ,电子 交换 系统 
Electronic Systems Simulator ,电子 系统 模拟 器 
EST Earliest Starting Time ,最 早起 动 时 间 
Educational Testing Services, ( 美国) 教育 考试 服务 处 
ETSI European Telecommunications Standards Institute ,欧洲 电信 标准 协会 
F 
FAQ Frequently Asked Questions ,常见 问题 解答 
FBI Federation of British Industries , 英国 工业 联合 会 
File Bus In ,文件 总 线 输入 
FCB File Control Block ,文件 控制 块 
FCC Federal Communications Commission, ( 美国 ) 通 信 委 员 会 
FDDI Fiber Distributed Data Interface , 光纤 分 布 式 数据 接口 
FDM Frequency Division Multiplexing , 频 分 多 路 复 用 
FDS Fast-access Disc Subsystem (CDC) , 快速 存 取 磁 盘子 系统 (CDC 公司 ) 


FielD Separator ,字段 分 隔 符 
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File Description Subsystem ,文件 描述 子 系统 
File Description System , 文件 描述 系统 
FIFO First In, First Out ,先进 先 出 队列 
FPM Facility Power Monitor, 设备 功率 监控 器 
File Protect Memory ,文件 保护 存储 器 
FPMRAM Fast Page Mode RAM ,快速 页 面 模式 随机 存 取 存储 器 


FPU Floating Point Unit, 浮 点 运算 
FQDN Fully Qualified Domain Name ,正式 域名 
FTP File Transfer Protocol ,文件 传送 | 输 ] 协议 
FX FiXed area, (磁盘 上 的 ) 固 定 区 

G 
GDI Graphics Device Interface , 图 形 设备 接口 


Generalized Data base Processor ,通用 数据 库 处 理 机 
Goal Directed Programming , 目标 引导 的 程序 设计 


GIF Graphics Interchange Format ,可 交换 的 图 像 文 件 
GMA General Microprocessor Architecture ,通用 微 处 理 机 体系 结构 
GMAT Greenwich mean astronomical time 格林 尼 治 标准 天 文 时 
GML Generalized Markup Language ,通用 标记 语言 
GMR G-Magnetoresistive Heads , G 磁 阻 磁头 
GMT Greenwich Mean Time ,格林 尼 治 标准 时 间 
Generalized MultiTasking ,广义 多 重任 务 处 理 
GNP Gross National Product, 人 均 国 民生 产 总 值 
GPP General Purpose Processor ,通用 处 理 机 
GPRS General Packet Radio Service , 通用 分 组 无 线 业 务 
GPS Global Position System , 全 球 定 位 系统 


General Problem Solver ,通用 问题 求解 程序 ,通用 解 题 程 序 
General Program Solution ,通用 程序 解 
General Programming Subsystem , 通用 程序 设计 子 系 统 
General Purpose Simulation ,通用 模拟 
General Purpose Simulator ,通用 模拟 程序 
GSM Global System( Standard) for Mobile Communications , 全 球 数 字 移 动 电 
话 系统 
Generalized Sequential Machine ,通用 序列 计算 机 
Graphics System Module ,图 ( 形 ) 系 统 模 块 
GUI Graphics User Interface , 图 形 用 户 界 面 
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HSD 


HTML 


HTTP 
HWM 


YO 
IAAF 
IAB 
IAC 


IC 


ICC 


iCOMP 


ICP 
ICQ 


ID 


IDC 


IDDD 
IDE 


IDL 


H 


Hardware Safety Device ,硬件 安全 装置 
Hypertext Markup Language , 超 文 本 标记 语言 
Hypertext Transfer Protocol , 超 文 本 传输 协议 
HighWay Memory ,总 线 存 储 器 

HardWare Monitoring ,硬件 监视 


I 


Input/Output ,输入 输出 

International Amateur Athletic Federation ,国际 业余 田径 联合 会 
Internet Architectrue Board Internet ,架构 委员 会 
Information Analysis Center ,信息 分 析 中 心 

Institute for Advanced Computation ,高 级 计算 技术 研究 所 
International Advisory Committee , 国际 咨询 委员 会 
International Association for Cybernetics , 国际 控制 论 协会 
Internationl Algebaic Language, 国际 代数 语言 
InterChange ,高 速 公 路 转换 出 入 口 

Integrate Circuit , 集成 电路 

Instruction Counter , 指令 计数 器 

International Compute Centre , 国际 计算 中 心 


Intel Comparative Microprocessor Performance, 微 处 理 器 效率 标准 。 由 


Intel 公司 提出 ,用 于 对 Intel CPU 的 相对 性 能 做 出 直观 比较 的 指标 
Internet Content Provider , Internet 内 容 提供 商 

Initial Connection Protocol , 初始 连接 协议 

I Seek You ,网络 寻呼机 

IDentification ,标识 (符号 ) ,( 身 份 ) 识别 

IDentification characters , 标识 字符 ,识别 符 

IDentifier , 标识 符 

Internet Data Center , Internet 数据 中 心 

Intelligent Disk Controller , 智能 磁盘 控制 器 

International Data Corporation , 国际 数据 公司 
International Development Center , 国际 开发 中 心 
International Direct Distance Dialing , 国际 直接 长 途 拨 号 
Integrated Drive Electronics ,集成 电路 设备 

Integrated Development Environment ,集成 开发 环境 
Intelligent Device Electronics ,智能 设备 电子 接口 
Instruction Definition Language, 指令 定义 语言 
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IRC 


IRQ 
IS 


ISA 
ISAM 


Interface Description( Definition) Language ,接口 描述 (定义 ) 语 言 


Intermediate Data Description Language, 中国 数据 描述 语言 


Internet Explorer , Internet j| 5$, 2& 


Institute of Electrical and Electronics Engineers ,电气 和 电子 工程 师 学 会 


Internet Engineering Task Force ,Internet 工程 任务 组 
Internet Information Server , Internet 信息 服务 器 


Internet Message Access Protocol , Internet 消息 访问 协议 


International Mobile Equipment Identity ， 国 际 移动 设备 识别 码 


International Monetary Fund, [E Pr $t f 24e 28 2A 
Internet Protocol , 网 际 协 议 

Identification of Position ,位 置 标识 
Identification Point , 标识 点 

Image Processor , A 1% Xt #2 HL 

Imagery Processing , 图 像 处 理 

Impact Printer , 击 打 式 打印 机 

Index of Performance , 性 能 指标 

Information Processor ,信息 [ 情报] 处 理 机 
Internet Relay Chatting ,在 线 聊 天 系统 
Information Retrieval Center , 情报 检索 中 心 
Interrupt Request , 中 断 请求 

Impact Switch ,碰撞 式 开关 

Impulse Sender, 脉冲 发 送 器 

Incoming Sender ,输入 发 送 器 

Indexed Sequential ,索引 顺序 (方式 ) 
Information Science ,信息 科学 

Information Separator, (5 & 4^ fe 4 
Information Separator character ,信息 分 隔 符 
Industry Standard Architecture ,工业 标准 结构 
Index(ed) Sequential Access Method ,索引 顺序 存 取 方 法 


Integrated Switching And Multiplexing ,集中 转 接 和 多 路 复 用 (技术 ) 


Internet Server API( Internet Server Application Programming Interface ) , 


为 Microsoft 所 提 的 Internet server 的 API 

Integrated Services Digital Network , 综合 业务 数字 网 
International Standards Organization , 国际 标准 化 组 织 
Internet Service Provider , Internet 服务 提供 者 

Input Signal Voltage ,输入 信号 电压 

Intensified Silicon Vidicon , #4 7% Zi 4 ( $E ) W14 /& 
Information Technology ,信息 技术 


J 


J2EE Java 2, Enterprise Edition , 一 种 应 用 开发 工具 
JPEG Joint Photographic Experts Group , 联合 图 像 专 家 组 (JPEG 编码 及 压缩 
标准 ) 
下 
KDE Keyboard Data Entry ,键盘 数据 输入 
L 
LAN Local Area Network ,局 (部 区 ) 域 网 ( 络 ) 
LBA Logical Block Address , 3? £x 3% 4i LE 


Laminar Bus A, 4? E i$ 7X A 
Linear Bounded Automaton, 线性 有 界 自 动机 
Local Bus Adapter, 局 部 总 线 转 接 器 


LCD Liquid Crystal Display ,液晶 显示 

LED Large Electronic Display ,大 型 电子 显示 器 
Light Emitting Diode ,发 光 二 极 管 

LHN Local Haul Network , 局 (部 区 ) 域 网 ( 络 ) 

LIFO Later In, First Out ,后进 、 先 出 队列 

LS Laser Servo, 激光 伺服 

LSI Large Scale Integration ,大 规模 集成 (电路 ) 


Last Segment Indicator ,最 末 段 指示 符 
Logic Status Indicator , 3£ £& 3A A 48 78 # A ) 
Langelier Saturation Index , 衣 格 利 尔 饱 和 指数 (化 学 ) 


LSIC Large Scale Integrated Circuit , 大 规模 集成 电路 

LSL Ladder Static Logic , 4 Ø $$ 437 $ 

LVDS Low-Voltage Differential Signaling ,低压 差分 信号 
M 

MAN Metropolitan Area Network , 城 域 网 

MAT Machine-Aided Translation ,机 器 辅助 翻译 

MAU Media Access Unit, 介质 访问 单元 

MBA Main Battle Area, + X EX [X 


Master of Business Administration ,工商 管理 硕士 
MassBus Adapter ,总 线 转 接 器 
MBCS Multi-Byte Character Systems, & ¥ i ¥ 4 A 4,38 E 4, HF HW ANSI F 
fe 
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MC 
MCA 
MCDBA 
MCI 


MCSE 
MCSP 
MDK 
MFC 
MIDAS 
MIDI 
MIME 


MIPS 
MIS 


MMC 


MO 
MOD 
MPC 
MPEG 


MPU 
MR 
MSDEV 


MSDN 
MSI 
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MicroComputer ,微型 计算 机 

Micro Channel Architecture , 微 通道 结构 

Microsoft Certified Database Administrator , 微软 认证 数据 库 管 理 员 
Multimedia Control Interface ,媒体 控制 接口 

Magnetic Core Storage , £& 75 ££ fid 2& 

Maintenance-data Collection System ,维修 数据 收集 系统 
Management Control System , 管理 控制 系统 

Master Control Set, 主 控 装 置 

Master Control Station, + 7 ( +|) 3 

Master Control System, + 4 ( 4] ) 系统 

Microsoft Certified Systems Engineering ,微软 认证 系统 工程 师 
Microsoft Certified Solution Provider , 微软 认证 解决 方案 提供 者 
Multimedia Development Kit, 多 媒体 开发 工具 包 

Microsoft Foundation Class, MS-Visual C++ 的 类 库 

Multiple Indexing Data Access System , 多 索引 数据 存 取 系 统 
Musical Instrument Digital Interface ,数码 音响 

Multipurpose Internet Mail Extension Protocol, % f 3& B] W) Pr Bh 4 a E 
协议 

Million Instructions Per Second ,每 秒 百 万 条 指令 

Management Information Science , 管理 信息 科学 

Management Information System , 管理 信息 系统 
Metal-Insulator-Semiconductor ,金属 -绝缘 体 - 半 导体 

Micro Information System , 微 信息 系统 

Mobility Information Server ,无线 通信 服务 器 

Main Memory Controller , 主 存储 器 控制 器 

Monthly Maintenance Charge , 月 维修 费用 

Microsoft Management Console ,微软 管理 控制 台 

Magneto Optical , # 25 2 

Message Output Descriptor , 报 文 ( 信 息 ) 输 出 描述 符 

Multimedia PC, 多 媒体 计算 机 

Moving Picture Experts Group ,运动 图 像 专家 组 (数字 电视 标准 ,包括 三 
个 部 分 : MPEG-Video , MPEG-Audio 和 MPEG-System ) 
MicroProcessing Unit, ft 4^ #2 4 

Magnetoresistive Heads , 磁 阻 磁头 

MS-Develop Studio, 微软 提供 的 软件 开发 平台 ,可 开发 VC++ 和 
VJ++ 等 系统 

Microsoft Developper Network ,微软 的 开发 者 网 络 

Middle Scale Integration , 中 规模 集成 电路 


MTA 


MTBF 
MTH 
MTS 
MTTF 
MTU 


MVP 


NaN 


NC 
NCAS 
NCB 
NCFC 


NCO 
NCP 


NCP/VS 


Mirror Server Link ,镜像 服务 器 链 路 

Microsoft Service Network , 微软 网 络 服务 
MS-Visual C++ ,微软 出 的 可 视 化 C++ 开发 平台 
Machine Translation ,机 器 翻译 

Magnetic Tape ,磁带 

Master Timer, = i Ej # 

Mean Time ,平均 时 间 

Measured Time ,测量 时 间 

MeasuremenT ,测量 ,量度 

Mechanical Translation ,机 器 翻译 

Mechanical Translation language ,机 器 翻译 语言 
Multiple Terminal Access , 多 媒体 终端 存 取 

Mail Transfer Agent, 邮件 传送 代理 

Mean Time Between Failures ,平均 故障 间隔 时 间 | 平均 无 故障 时 间 | 
Magnetic Tape Handler ,磁带 处 理 机 [程序 | 
Microsoft Transaction Server ,微软 事务 处 理 服务 器 
Mean Time To Failure ,平均 无 故障 时 间 

Maximum Transport Unit, (数据 的 ) 最 大 传输 单元 
Magnetic Tape Unit, 磁 带 机 

Memory Transfer Unit, $% fi & € ; ££ [i 28 Pz 35 BL 
Multiplexer and Terminal Unit, 多 路 转换 器 与 终端 装置 
Multi-User Dungeons, 多 用 户 网 络 游戏 

Multi-User Domuins, 多 用 户 领域 

Multi-Variable Programming , 多 变量 程序 设计 


N 


Not a Number, 非 数值 (IEEE 浮 点 运算 规定 其 用 来 表示 没有 意义 的 表 
达 式 ) 
Network Card ,网卡 
National Center for Supercomputing ,国际 超级 计算 机 中 心 
Network Control Block ,网 络 控制 部 件 ( 网 络 控制 程序 块 ) 
the National Computing and Networking Facility of China, 中 家 计算 
机 与 网 络 设施 
Number Controlled Oscillator, 数控 振荡 器 
National Communications information Plan, 国 家 通信 情报 计划 
Network Control Processor , 网 络 控制 处 理 机 
Network Control Program , 网 络 控制 程序 
Network Control Program/ Virtual Storage , 网 路 控制 程序 存储 虚拟 
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NDIS 


NetBEUI 


NIC 


NII 
NIP 
NIT 


NNTP 


NOS 
NS 


NSF 
NSP 


NT 
NTSC 


NVF 


NYSE 


OA 


OAW 
OBJ 
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Network Driver Interface Standard ,网络 驱动 器 接口 标准 
Non-Destructive Inspection Standard, ( 日 本 ) 非 破坏 性 检查 ( 协会) 标准 
NetBIOS Extended User Interface ,网 络 基本 输入 输出 系统 扩展 用 户 接口 
Network Information Center ,网络 信息 中 心 

Network Interface Card , 网 络 接口 卡 

Network Interface Control , 网 络 接口 控制 

Normal Input Cause ,正常 输 入 条 件 

National Information Infrastructure , 国家 信息 基础 设施 (信息 高 速 公 路 ) 
Network Information Center, 网络 信息 中 心 

National Applied Information Technology Certificate ,全 国 计 算 机 应 用 技 
术 证 书 考试 

Network News Transfer Protocol , 网 络 新 闻 传 输 协 议 (USE-NET) 
Network Operation System, 网络 操 作 系 统 

NanoSecond, 纳 ( 诺 ) 秒 

Network Services, 网络 服务 

New Series, 新 系列 

New Signal, 新 信号 

New System, 新 体制 ( 系统 ) 

No Signal, 无 [ 非 | 信号 

NonSequenced , 非 ( 顺 ) 序 的 

NonStandard , 非 标 ( 准 ) ,规格 外 

Not Signed ,无 签名 

the National Science Foundation , 国家 科学 基金 会 

Network Service Protocol , 网 络 服务 协议 

NonStandard Part approval , 非 标准 部 件 审 定 

Numeric SPace character ,数字 间隔 符 

Numeric Subroutine Package ,数字 子 程序 包 

New Technology , 新 技术 

National Television Systems Committee ,NTSC 制式 ,全 国电 视 系统 委员 
会 制式 

Network Virtual File , 网络 虚拟 文件 

New York Stock Exchange , 4l Z1 ik 2$ 2c 4j Fr 


O0 


Office Assistant , 办 公 助 手 

Office Automation, 办公 自动 化 

Optically Assisted Winchester , 光学 辅助 温 氏 技术 
Object( objection ) , 物体 


OCX 
ODBC 
ODE 
ODI 
OEM 
OH 
OLE 
OOD 
OOP 
OOPL 
OpenGL 
OS 

OSD 
OSI RM 
OWL 


PZP 
PAL 
PC 
PCB 


PCI 


PC 
PCM 


PCMCIA 


PD 


PDA 


OLE Customer Control , Xt & ££ 3 5 A Hil f£ JF 

Open Database Connectivity ,开放 式 数据 库 互 接 

Orbit Data Editor assembly , 轨道 数据 编辑 程序 汇编 

Open Data-Link Interface ,开放 式 数据 链 路 接口 

Original Equipment Manufacturer ,原始 设备 制造 厂家 

Off Hook , 摘 机 

Object Linking and Embedding ,对象 链接 和 岁入 

Object Oriented Design ,面向 对 象 设 计 

Object Oriented Programming ,面向 对 象 的 程序 设计 

Object Oriented Programming Language, ,面向 对 象 的 程序 设计 语言 
Open Graphics Library ,开放 式 图 形 界 面 

Operating System , 操作 系统 

On Screen Display , 同房 显示 

Open System Interconnect Reference Model ,开放 式 系统 互联 参考 模型 
Object Window Library , Borland C++ 的 类 库 ( 对 象 窗口 库 ) 


P 


Peer To Peer ,点 对 点 

Phase Alternating Line ,PAL 制式 

Personal Computer ,个 人 计算 机 

Page Control Block , 页 控制 块 

Power Circuit Breaker ,电源 断路 开关 

Printed Circuit Block , 印 制 电路 板 

Process Communication Block ,进程 通信 块 
Process Control Block ,进程 控制 块 

Program Control Block ,程序 控制 块 

Program Controlled Interruption , 程序 控制 中 断 
Peripheral Component Interconnect , PCI 总 线 
Printer Control Language ,打印 机 控制 语言 
Pulse Code Modulation , 脉冲 编码 调制 

Plug Compatible Mainframe , # 7 3€ & = TL 

Plug Compatible Manufactures , 接 插 兼容 制造 厂 
Plug Compatible Memory , 插 接 兼容 存储 器 
Personal Computer Memory Card International Association ,个 人 计算 机 存 


储 卡 国际 协会 
Phase Change Rewritable Optical Disk Drive, JH 7k A 4 E & #5 3¢ Zi Jk 
动 器 


Parallel Data Adapter , 并行 数 据 适 配器 
。 189 * 


Personal Digital Assistant ,个 人 数字 助理 
Personal Data Assistance ,个 人 信息 (数据 ) 终 端 (助手 ) 
Physical Device Address ,设备 物理 地 址 


PDF Portable Document Format, 可 移植 文档 格式 (Adobe) 
PERL Practical Extraction and Report Language ,实用 摘录 和 和 报告 语言 
PFD Position Finding Device ,位 置 测定 位 , 测 位 仪 

Pulse Frequency Diversity , 脉冲 频率 分 集 
PGP Pretty Good Privacy , PGP 加 密 程序 
PHP Personal Homepage Program , UNIX 的 ASP 
PIN Personal Identification Number ,个 人 识别 号 
PLC Programable Logic Controller , "| 25 427 | 4 
PnP Plug and Play , 即 插 即 用 
PPP Peer-Peer Protocol( Point to Point Protocol) , 端 对 端 协议 
PRI Primary Rate Interface , = 3€ # t H 
PS Packet Switching ,分 组 [ 包 ] 交 换 技 术 

PostScript, 页 描述 语言 文件 的 后 绥 
PVC Permanent Virtual Circuits ,永久 有 效 电 路 
PWS Personal Web Server ,个 人 Web 服务 器 

Q 

QC Quality Control , 质量 控制 
QL QuasiLinear , 准 线性 的 


m an 


Query Language, 查询 语言 
Quick Loading , 5:3 A A 


R 
RAD Rapid Application Development , 快速 应 用 程序 开发 
RAID Redundant Arrays of Inexpensive Disks , 廉价 元 余 磁 盘 阵 列 
RAM Random Access Memory , 随机 存储 器 
RARP Reverse Address Resolution Protocol , 反 向 地 址 解析 协议 
Royal Academy of Music, ( 英国) 皇家 音乐 学 院 
RC Radix Complement , 补 码 ,基数 补 码 


Reader Code , 阅读 器 编码 

Real Circuit , 实 电路 

Receive Common, #67 W% 

Record Check, 记录 校对 

Record Count, 记录 计数 

Regional Center, ( 电话) 分局; 区域 中 心 
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RISC 


RTTI 


SAP 

SAT 

SB 
SB-ADPCM 
SCADA 
SCSI 

SDK 

SDLC 


SDRAM 
SGI 
SGML 


SIMD 
SIMM 
SLIP 
SMDS 
SMP 


Remote Computing, 远程 计算 

Rambus Dynamic RAM ,存储 器 总 线 式 动态 随机 存 取 存储 器 
Request For Comment , 请 求 说 明 , Internet 标准 (草案 ) 
Residual Field Count, 剩余 区 段 计 数 

Record Field eXchange, ,记录 字段 交换 

Reduced ( Reduction) Instruction Set Computer, 精简 指令 集 ( 系 统 ) 计 
算 机 

Reduced Instruction Set Cycles ,精简 指令 系统 周期 
Run-Length Encoding , 行 [ 游 ] 程 长 度 编码 ( 法 ) 

Read Only Memory ,只 读 存 储 器 

Report Program Generator ,报表 程序 生成 程序 

Rich Text Format,Rich-Text 格式 

Resistor Transistor Logic , E IH dà fA 39 2x (E g) 

Real-Time Language ,实时 语言 

Real-Time Link ,实时 链 路 

Resistor Transistor Logic ,电阻 唱 体 管 逻辑 ( 电路 ) 

RunTime Library ,运行 时 间 库 

Run Time Type Information ,运行 时 间 类 型 信息 


S 


Service Access Point , 服务 访问 点 
Storage Allocation Table ,存储 分 配 表 
Safe Browsing ,安全 浏览 技术 
Sub-Band-Adaptive Differential Pulse Code, 子 带 - 自 适应 差分 脉冲 编码 
Supervisory Control And Data Acquisition, 监察 控制 和 数据 采集 
Small Computer System Interface ,小 型 计算 机 系统 接口 
Software Development Kit ,软件 开发 工具 包 
Synchronous Data Link Control , 同步 数据 链 路 控制 (协议 ,此 即 全 称 ) 
Software Development Life Cycle ,软件 开发 生命 周期 
Synchronous Dynamic RAM, ,同步 动态 随机 存 取 存 储 器 
Silicon Graphics Inc. ,美国 图 形 工 作 站 生产 厂商 
Standard for General Markup Language ,通用 标记 语言 标准 
Standard Generalized Markup Language ,标准 通用 标记 语言 
Single Instruction Multiple Data stream , 单 指令 多 数据 流 
Single In-line Memory Module, , 单列 直 插 式 内 存 组 件 
Serial Line Interface Protocol, 串 行 线路 接口 协议 
Switched Multimegabit Data Service , 转换 多 焰 位 数据 服务 
Simple Management Protocol , ( TCP/IP) 简单 管理 协议 
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SMTP 
SNA 
SNAP 


SPD 
SPEC 


SOL 


SQL/DS 


SR 


SRAM 
SSI 
SSL 
STL 
STR 


SVGA 


TCP 


TDM 


TRPG 
TSR 


UCE 


UCS 
UDP 
UI 
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Symmetric Multiple Processor ,对 称 多 处 理 器 

Simple Mail Transfer Protocol , 简单 邮件 传输 协议 

Systems Network Architecture ,系统 网 络 体系 结构 
Semantic Network Array Processor ,语义 网 络 阵 列 处 理 机 
System for NAtural Programming , 自然 程序 设计 系统 
System Network Activity Program ,系统 网 络 动作 程序 
System Network Architecture Program, 系统 网 络 结构 程序 
Software Product Description ,软件 产品 说 明 书 

Systems Performance Evaluation Committee ( System Performance 
Evaluation Cooperative Consortium) , 系统 性 能 评定 委员 会 
Structured Query Language ,结构 化 查询 语言 

Structured Query Language/Data System, , 结构 化 查询 语言 /数据 系统 
Shift Register , 移 位 寄存 器 

Special Register ,专用 寄存 器 

Static Random Access Memory ,静态 随机 存 取 存 储 器 
Small Scale Integration , 小 规模 集成 电路 

Security Socket Layer ,安全 套 接 层 

Standard Template Library ,标准 模板 库 

STatus Register ,状态 寄存 器 

Synchronous Transmitter/ Receiver , 同步 发 送 /接收 器 
Super Video Graphics Array ,增强 型 视频 图 形 阵列 显示 卡 


T 


Transmission Control Protocol, 传 输 控 制 协 议 

Time Division Multiplexing ,时 分 多 路 复 用 

Table Role Play Game, 呆 上 角色 扮演 游戏 

Temporary Storage Register, 暂 存 寄存 器 

Terminate and Stay Resident, 驻 留 内 存 ;终止 并 驻 留 ,终止 后 驻 留 内 存 
(程序 ) 


U 


Uninterruptible Computer Power , 计算 机 用 不 间断 电源 ,无 中 断 的 计算 机 
电源 

Unit Construction Principle , 单元 结构 原理 

Universal Code Set ,通用 多 八 位 编码 字符 集 

User Datagram Protocol, £] > 2x 4E 4k ix 

Unnumbered Information ( frame) ,未 编号 信息 ( 帧 ) 

User Interface, H FP JE [du | 


UMA 
UML 
UNC 


UNIX 


UPS 
URL 
USB 


VBX 
VCD 
VCL 

VDM 


VESA 
VGA 
VIP 
VLB 
VLSI 
VM 
VML 
VMT 
VOD 
VOX 


VRML 
VSS 
VTM 


W3C 


Ultra ATA/66 ,一 种 硬盘 接口 技术 

Upper Memory Area, 上 端 内 存 ( 内 存 中 640KB 到 1MB 的 区 域 ) 

Unified Modeling Language ,统一 建 模 语言 

Universal Naming Conversion, ,通用 命名 标准 

Universal Navigation Computer ,通用 导航 计算 机 

Uniplexed Information and Computing System( CS 用 X 代 和 荐 ) ,一 种 多 用 
户 的 计算 机 操作 系统 

Uninterruptible Power Supply ,不 间断 电源 

Uniform Resource Locators ,统一 资源 定位 器 

Universal Serial Bus, ( Intel 公司 开发 的 ) 通 用 串 行 总 线 


V 


Visual Basic Custom Control, "T ? (^, BASIC 语言 程序 
Video Compact Disc , 19. 2 Ej x 06 # 

Visual Component Library , 可 视 化 控件 库 

Varian Data Machines ,Varian 数据 机 

Video Display Module , 视频 显示 组 件 [ 模块] 

Vienna Development Method ,维也纳 研制 法 

Video Electronics Standards Association ,视频 电子 标准 协会 
Video Graphics Array ,视频 图 形 阵列 显示 卡 

Very Important Person, 大 人 物 , 要 人 

VESA Local Bus, 由 VESA 开发 的 一 种 局 部 总 线 
Very Large Scale Integration ,超大 规模 集成 电路 
Virtual Machine ,虚拟 机 

Virtual Memory Level, ,虚拟 存储 级 

Virtual Method Table ,虚拟 方法 表 

Video-On-Demand ,视频 点 播 

Voice-Operated Control, 声控 器 

Voice-Operated Relay Circuit, 声控 继电器 电路 
Voice-Operated Transmission ,声控 传输 

Virtual Reality Moduling Language ,虚拟 现实 造型 语言 
Visual SourceSafe ,数据 库 格式 

Vacuum Tube Modulator ,真空 管 调制 咒 

Vocal Tract Models , 声 道 [ 发 声 系 统 ] 模 型 


W 


World Wide Web Consortium, 国际 共同 认可 的 非 盈利 组 织 , 其 宗旨 为 尽 
力 提 升 与 维护 万 维 网 
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WYSIWYG 
WWW 


XML 
XSL 
XSLT 
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Wide Area Information Server , 广 域 信 息 服 务 器 
Wide Area Net ,广域网 

Wireless Application Protocol , 无线 应 用 协议 
World Bank ,世界 银行 

Wide Band, 55, ( 91) #7 

Wirte Buffer, 写 入 缓冲 区 ( #) 

WideBand Coupler, 55 ir #44 25 

Wave-length Division Multiplexing , 3X 4? & % & H 
Windows Media Audio , 微软 音乐 媒体 文件 
Wireless Markup Language ,无 线 标记 语言 
Warsaw Treaty Organization , 华 约 
Write-To-Operator , 写 给 操作 员 ( 的 信息 ) 

What You See Is What You Get ,所 见 即 所 得 
World Wide Web, 7; 2& W] 


X 


eXtensible Markup Language, 可 扩充 标记 语言 
eXtensible Stylesheet Language, 可 扩充 样式 语言 
eXtensible Stylesheet Language Translation, 可 扩充 样式 转换 语言 


附录 D 计算 机 常用 词汇 
A 


access control ”访问 控制 

Access Control List( ACL) 访问 控制 列表 

Active Group ”活动 组 

Active Server Pages( ASP) “一 种 服务 需 端 的 脚本 环境 ,可 以 用 来 创建 动态 Web 页 或 
编译 Web 应 用 程序 

ActiveX Controls ActiveX 控件 

activity ”活动 

Address Resolution Protocol( ARP) ”地 址 解析 协议 

agent 代理 

Anonymous File Transfer Protocol( 匿名 FTP) ”匿名 文件 传输 协议 

applet ”小 程序 

Application Programming Interface( API) ”应 用 程序 接口 

array ”数组 

Asynchronous Transfer Mode( ATM) ”异步 传输 模式 

asynchronous transmission ”异步 传输 

authorization ”授权 


B 
bandwidth ”带宽 
baud 波 特 
binding 2E 
bits per second( bps) ”位 /每 秒 
browser 浏览 : 
C 


cache RERIT 
call 调用 
callback function 回 叫 功能 
catalog agent 目录 代理 
class 类 
customer ”客户 
client/server architecture “客户 端 / 服 务 需 结构 
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clustering ”群集 

colocation ”托管 

commit ”提交 

Common Gateway Interface( CGI) ”公共 网 关 接 口 
Component Object Model (COM) 组件 对 象 模型 
component 组 件 

concurrency 并 发 

contro] 控件 


D 


data consistency “数据 一 致 性 

Data Encryption Standard( DES) ”数据 加 密 标 准 
datagram ”数据 报 文 

data provider ”数据 提供 程序 

data source ”数据 源 

Data Source Name( DSN) ”数据 源 名 

data source tier 数据 源 层 

data warehouse ”数据 库 仓库 

deadlock tii 

debugger 调试 大 

default document ”默认 文档 

default gateway 默认 网 关 

design time 设计 时 间 

dial-up ”拨号 

digital signature ”数字 签名 

Discrete Fourier, Transform( DFT) ”离散 式 健 里 叶 变 换 
Discrete cosine, Transform( DCT) ”离散 余弦 变换 
domain name 域名 

Domain Name System( DNS) 域名 系统 

dual interface ”双重 接口 

dynamic binding AA 

Dynamic Host Configuration Protocol( DHCP) ”动态 主机 配置 协议 
dynamic HTML(DHTML) 动态 HTML 
Dynamic-Link Library( DLL) 动态 链接 库 
dynamic page 动态 页 


E 


e-commerce ”电子 商务 
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e-mail 电子 邮件 

early binding ”前 期 捆绑 

encapsulate ”封装 

encryption JN 

Ethernet LAK 

event 事件 

event handler 事件 句柄 

event handling 事件 处 理 

event method 事件 方法 

exception ”异常 

executable program ”可 执行 程序 

expires header 过 期 头 

extended partition ”扩展 分 区 

eXtensible Markup Language( XML) 可 扩展 标记 语言 
eXtensible Stylesheet Language( XSL) 可 扩展 样式 表 语 言 


F 


failback ”故障 恢复 

failover ”故障 转移 

fat server HERR es 

Fast Fourier, Transform( FFT) ”快速 全 里 叶 变 换 
fault tolerance ” 容 销 

File Allocation Table( FAT) ”文件 分 配 表 

file system( FAT) ”文件 系统 

file name extension mapping 文件 名 扩展 名 映射 
file space ”文件 空间 

File Transfer Protocol( FTP) 文件 传输 协议 
filler Sitz 

filtering, host name 过滤, 主机 名 

filtering, IP address ”过 滤 ,IP 地 址 

firewall 防火 墙 

footer Ji fia 

form ”表单 

frame i 

Frequently Asked Questions % Yi [n] i 

friendly name 好 记 的 名 称 

FrontPage Server Extensions FrontPage “服务 需 扩 展 
failure to access code page font file 访问 代码 页 字库 文件 失败 
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failure writing to device SARKARI 

Fatal error; can not allocate memory for DOS 不 能 为 DOS 分 配 内 存 
FDD controller failure 4k Zt Tz ibl gs m pat 

file access denied 拒绝 文件 访问 

file allocation table bad 文件 分 配 表 损坏 

File already exists. Overwrite? ”文件 已 存在 , 需 履 六 吗 ? 
file can not be converted 文件 不 能 被 转换 

file cannot be copied onto itself ”文件 不 能 目 我 复制 

file cannot to EXE2BIN 文件 不 能 转换 成 EXE2BIN 

file creation error 文件 建立 错误 

file damaged, cannot recover 文件 被 破坏 ,不 能 恢复 

file environment error 文件 环境 错误 

file error 文件 错误 

file exists cross-device link ”文件 存在 交叉 链接 

file larger than 64KB, cannot load 文件 大 于 64KB , PRERE 
file name must be specified ”必须 指定 文件 名 

file read aborted ”文件 读 取 失败 

file sharing conflict ”文件 共享 冲突 

file were backed up ”文件 备份 

first diskette bad or incompatible ”第 一 张 磁 盘 损 坏 或 不 兼容 
Fourier transform (5 Hi aed 


G 


gateway Pe 

Globally Unique Identifier( GUID) 全球 唯一 标识 符 
Graphical User Interface(GUI) ”图 形 用 户 界 面 
Graphics Interchange Format(GIF) 图 形 交 换 格 式 


H 


heap (Windows heap) ”堆栈 ( Windows 堆栈 ) 

home directory 3X: Ho 

home page 主页 

host 主机 

host name 主机 名 

hyperlink ” 超 链 接 

hypertext ” 超 文本 

Hypertext Markup Language( HTML) 超 文本 标记 语言 
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icon 图像 

ideal noise diode “理想 噪声 二 极 管 

identification ”识别 

identification code ”识别 码 

identification, exchange( XID) 交换 识别 
identifier 识别 码 

identifier, service access point(SAPI) ”服务 存 取 端 识别 人 码 
identifier, terminal endpoint( TEI) 终端 末端 识别 三 
identifier, terminal equipment( TEI) ”终端 设备 识别 公 
identifier, virtual circuit( VCI) ”虚拟 电路 识别 人 码 
idle 闲置 

idle character 闲置 字符 

if-then-else  Z7------ yi... --- 否则 

illegal character ”非法 字符 

illegal code ”非法 代码 

illegal instruction ”非法 指令 

illumination 照明 

image ”图 像 

image analysis ”图 像 分 析 , 析 像 

image generator ”图像 生成 如 

image map 图像 图 

image mapping 图像 映 射 , 图 像 变 换 

image processing system ”影像 处 理 系统 

image sensor 2 [gk IW as 

image transfer 影像 转移 

image, bit-mapped raster 位 映射 光栅 影像 
image, erect IE Y. f 

image, ghost Hits; Hs? 

image, inverse {83 

image, inverted 2) 7 A 

image, real %1% 

image, virtual ”虚像 

image-acquisition ”影像 采集 

immediate access ”快速 存 取 

immediate instruction 立即 指令 


impact printer 击 打 式 打印 机 
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impact strength 抗 冲击 强度 
impairment 损毁 ;破坏 

impulse YP 

impulse current ”脉冲 电流 
incremental tar fy 

index 索引 

index hole 索引 孔 

index register I| 2f ff án 

index table “索引 表 

index, disk ”磁盘 索引 

indexed file 索引 文件 

indexing, cylinder surface f#ZFEM ASIA 
indicated value 指示 值 

indication ”指示 

indices ”指数 

indirect addressing ”间接 寻 址 
Information Sciences Institute( ISI) ”|[ 美 | 信息 科学 协会 
information interchange ”信息 交换 
information retrieval ”信息 检索 
information storage ”信息 储存 
information theory 信息 理论 
infrared (IR) 红外 线 

inhibit 禁止 ;阻止 

initial access latency 初始 存 取 等 待 时 间 
initial failure ”初始 故障 

ink-jet printer $583 4T ENHL 
input ”输入 

input device ”输入 装置 
Input/Output( L/O) 输入 输出 
insert ”加 入 ;插入 

installation manual ”安装 说 明 书 
instantiation ” filz 


instruction 1&4 


instruction cache $4 Hi EZ PEE aS 
instruction code ”指令 代码 

instruction cycle ”指令 周期 

instruction decode “指令 解码 
instruction format 指令 格式 
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instruction length 指令 长 度 

instruction path ”指令 通路 

instruction sequence 指令 序列 

instruction type ”指令 类 型 

instruction, computer-aided(CAI) ”计算 机 辅助 教学 
instruction, cycles-per-( CPI) 每 指令 周期 数 
instruction, illegal 非法 指令 

integer 整数 

integrated circuit, very large scale( VLSI) 超大 规模 集成 电路 
integrated data processing ”综合 数据 处 理 

Integrated Services Architecture( ISA ) 综合 业务 结构 
Integrated Services Digital Network(ISDN) 综合 服务 数字 网 络 
integration circuit ”积分 电路 

Intellectual Property Right( IPR) 知识 产权 ,专利 
intelligence, artificial( AI) AT% fE 

Intelligent Network(IN) ”智能 网 络 

Intelligent Peripheral(IP) 智能 外 设 

intelligent terminal ”智能 型 终端 机 

intelligent test ”智能 测试 ,智力 测验 

intensity “亮度 ;强度 

intensive, central processing unit 中央 处 理 需 密集 
interaction XH. 

intercept ÆT 

intercept call $r Ha iE 

interchannel interference “通道 间 干 扰 

intercom ”内 部 通信 

interface repository 接口 库 

interface, bus ”总 线 接口 

interface, computer graphics( CGI) “计算 机 图 像 接口 
interface, data ”数据 接口 

interface, graphical user( GUI) 图像 用 户 接口 
interference “干涉 ;干扰 

interference field strength 十 扰 场 强度 

interlace scan hamiri 

interlaced ”交织 的 ;隔行 的 

interlaced GIF 隔行 GIF 格式 

interlaced scanning ”交织 扫 摘 ;隔行 扫 摘 
interpretation — Ae TE 


- 201 - 


interpreter 解 译 程序 

interpreter, language 语言 解 译 程序 
interrupt "Flt 

interrupt acknowledge — "PIBrff iA 
interrupt bus Ply, 2k 

inverse 反问 ;倒数 

Inverse Fast Fourier Transform( IFFT) BE (8 Hun orte 46 
inverse image 2 (& 

ion gun ”离子 枪 

ip address IP 地址 

isolating switch ”切断 开关 , Breeds 
isolation boundary þa AWA 


jack 插座 ; 蛤 孔 

jamming 干扰 ;干扰 杂音 
jamming margin 干扰 极限 
jitter 抖动 

jitter, horizontal 水平 抖动 
jitter, phase ”相位 抖动 

jitter, timing 时序 抖 动 

jitter, vertical 垂直 抖动 

joint 结 ; 结 点 

joystick  $£fT 

jump KER 

jump, indirect ”间接 跳 越 
junction 25; E £2 ; 21h ei 
junction depth ”连接 深度 
junction diode RIKE 
Junction Field-Effect Transistor( JFET) ZEAL H RUM E 
Junction Isolation(JI) 连接 隅 离 


K 


kernel 核心 

key value 关键 值 

key, soft KHE 

keyboard ”键盘 

keying, on-off(OOK) “开关 键 控 
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keyword XF 
know-how ”技术 知识 
knowledge base ”知识 库 


label 标记 ;标志 
language interpreter 语言 解 译 程 序 
language, FORTRAN FORTRAN 语言 
language, graphics ”图 像 语言 
language, hypertext markup( HTML) 超 文本 标记 语言 
language, structured query( SQL) ”结构 化 查询 语言 
language, virtual reality modeling( VRML) 虚拟 现实 标记 语言 
laptop computer 膝 上 型 计算 机 
laser 激光 
latch MF 
latency, interrupt 中断 等 待 时 间 
layer, board 电路 板 层 
layer, data link 数据 链 路 层 
layer, hardware interface ”人 硬件 接口 层 
layer, link PEJE 
layer, network 网络 层 
layer, network interface( NIL) 网络 接 口 层 
layer, session ”会 话 层 
layer, transmission ”传输 层 
layout 布局 
layout ,circuit 电路 布局 
length, focal (f)” 焦 长 ;焦距 
length, instruction ”指令 长 度 
lens ”透镜 
library 程序 库 
license #24 ,许可 
licensing standard ”许可 标准 
life cycle 生命 周期 
Light Emitting Diode(LED) 发光 二 极 管 
light sensitivity ”光敏 度 
light source ”光源 
line printer 行 式 打印 机 
linear power supply 线性 电源 供应 
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Liquid Crystal Display( LCD) W f ibo ý 
load, full 全 负载 

load, half ^E faz 

location ”定位 

locator EMLA 

logarithm ”对 数 

logic ”逻辑 

logic AND(LAND) 逻辑 与 
logic OR(LOR) “逻辑 或 

logic, complementary ”互补 逻辑 
loop Shit 

loop antenna ”环形 天 线 


luminous intensity JG 


machine address ”机 需 地 址 

machine code ”机 需 代 码 

machine language ”机 器 语言 

macro 44 

magnetic field 磁场 

mail server — Hbf FH S as 

mailbox ”邮箱 

mainframe ”大 型 计算 机 

maintenance ”维修 ;检修 

malfunction ”故障 ;失灵 

man-machine interface ”人 机 接口 

management, configuration ”配置 管理 
management, distributed data( DDM) 分 布 式 数 据 管理 
management, dynamic storage ATFs thE XE 
management, library 程序 库 管理 

management, network ”网 络 管理 

map ”映射 ;图 ;图 像 ;变换 

mapping, topological ”拓扑 绘图 

margin 边 绿 ;界限 


mark ”记号 
marker 记号 ;标记 
matrix [4 


matrix circuit 和 矩阵 电路 
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media 媒介 ;媒体 

Media Access Control(MAC) 媒体 存 取 控制 

medium 介质 ;媒体 

mega-(M) HJ 

mega-cycle A 7j Jali} 

megabit(Mb) 4 JJ fiz 

megabyte(MB) HAF 

megacell 百 万 储存 单元 

megapixel ANR 

memory FFR 

memory available 可 用 存储 需 

memory bank 存储 天 组 

memory bus 存储 右 总 线 

memory cell 存储 右 存 储 单元 

memory cell array 存储 全 存储 单元 阵列 

Memory Control Unit( MCU) “存储 需 探 制 单元 

memory controller( MEMC) “存储 需 探 制 需 

memory counter {FAri AU 

memory device “存储 需 需 件 

Memory Management Unit( MMU) “存储 需 管 理 单元 

memory, compact disc read only( CD ROM) GER Rieter tind 

memory , electrically erasable programmable read only( EEPROM) 电气 拭 除 式 可 编 
FE HABE EE in 

memory, electrically erasable read only( EEROM) BAIRI Rise ff fit as 

memory, erasable programmable read only(EPROM) = FJ fil X n] 2g fe Hue ff itas 

memory, flash RATE fits 

memory, programmable read only( PROM) “可 编程 只 读 存 储 需 

memory, random access(RAM) BENLE PUT MK 

memory, read only( ROM) “只 读 存 储 需 

memory, static random access(SRAM) 静态 随机 存 取 存储 需 

memory, video random access( VRAM) 视频 随机 存 取 存 储 需 

metabase ”元 数据 库 

metadata ”元 数据 

metalanguage ”元 语言 

micro- $m 

micro-instruction ”做 指令 

microcode (mfi 

microcomputer HAWL 

: 205 。 


micron 微米 
microsecond AEV 
milli- (m) Æ 

Million Instruction Bytes per Second( MIBS) ”每 秒 百 万 指令 字 方 
Million Instructions per Second( MIPS) ”每 秒 百 万 条 指令 
millisecond (ms) Æ#b 

mini-computer ”小 型 计算 机 

mirror effect ”镜像 效应 

mobile phone 移动 电话 

mode, asynchronous transfer( ATM) 异步 传输 模式 

mode, auto-detect ”自动 检测 模式 

mode, auto-zero “” 目 动 归 夫 模式 

mode, normal 正常 状态 ;正常 模式 

mode, power-down ”省 电 状 态 ;省 电 模 式 

mode, privileged ”特许 状态 ;特许 模式 

mode, protected ”保护 状态 ;保护 模式 

Modem 调制 解 调 大 

modulation ”调制 

modulation, amplitude( AM) 振幅 调制 

modulation, differential pulse code( DPCM) “ 差 动 脉冲 编码 调制 
modulation, frequency( FM) 频率 调制 

modulation, pulse code( PCM) “脉冲 编码 调制 

modulo( mod) ” 模 数 

motherboard ^R 

motion 运动 

Motion Picture Experts Group 1( MPEG-1) 活动 图 像 专家 组 规范 1 
Motion Picture Experts Group 2( MPEG-2) 活动 图 像 专 家 组 规范 2 
Motion Picture Experts Group 4( MPEG-4) 活动 图 像 专 家 组 规范 4 
motion estimator 运动 估算 量 ,移动 估算 右 

motion vector 运动 天 量 
motion, circular 圆周 运动 

motion, curvilinear 曲线 运动 

motion, period 周期 运动 

motion, projectile ” 抛 体 运动 

motion, rectilinear ”直线 运动 

motion, relative ”相对 运动 

mouse ”鼠标 

Multi-User Dimension( MUD) 多 用 户 空 间 
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multiple inheritance 多重 继承 

Musical Instrument Digital Interface( MIDI) RÝRA r- 1 HO 
musical scale 音阶 

mute ME 

muting BR a Fl il 

mutual inductance 互感 


mutual synchronization 互 同 步 
N 


nano- (n) efit: A 
National Center for Supercomputing Applications( NCSA) 国家 超级 计算 应 用 中 心 ， 


国家 计算 中 心 


negate ”否定 ; 非 
Nested loops — CE BE 
net 网 
network ”网 络 
Network Access Points( NAP) ”网 络 接 入 点 
network access server 网 络 接 人 服务 器 
network adapter WJ% iE Ad dt 
Network Address Translator( NAT) 网络 地 址 转换 器 , 28 Hot SERE 
network administrator ”网络 管理 员 
network architecture ”网 络 结构 
Network Control Protocol( NCP) ”网 络 控制 协议 
Network File System( NFS) ”网 络 文件 系统 
network function PX% PR 
Network Information Center( NIC) 网络 信息 中 心 
Network Interface Card( NIC) ”网 络 接口 卡 
Network Interface Unit( NIU) 网络 接 口 单 元 
network layer 网络 层 
Network Management Unit( NMU) 网络 管 理 单元 
network server ”网络 伺服 需 
network, digital ”数字 网 络 
network, distributed ”分布 式 网 络 
network, integrated services digital( ISDN) ”综合 服务 数字 网 络 
network, star 星 型 网 络 
network, token-ring 令 牌 环 网 络 
networking node 网络 结 点 
neural network ”神经 网 络 
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neutral ”中 性 

newsgroup ”新 闻 组 

nibble E515 

nick ZIJ; 74 ; T8 

nine's complement Fitil fi 
noise “噪音 ;噪声 

noise, impulse “脉冲 噪声 
non-conductor 非 导体 

normal 法 线 

normal mode 1E 4$ IS ; IEW Park 
notation ”符号 ;记号 

notch #40 

notebook computer 笔记 本 式 计 算 机 
notification message 通知 消息 

null 4E 

null characters ” 空 字符 

number 号码 ;编号 

number portability ZF n] fef TE, fn] TARTE 
number, node 了 网 点 编号 
numerical ”数字 的 ;数值 的 


object 目的 ; 物 ;对 象 

object distance “目标 距离 

object file 目标 文件 

object oriented ”目标 取 回 

object program ”目标 程序 

object-oriented language MX R A 
Object-Oriented Programming System( OOPS) 面 回 对 象 编 程 系统 
octal ”八进制 

off board 外接; 板 外 

offset address — fme HE 

offset, section [X Ez fm fe 

offset, segment | ZHEZ [i $2 

ohm 欧姆 

ohmmeter 电阻 计 

on-board 板 上 

on-board memory 在 板 存 储 需 , 板 上 存储 需 
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on-chip 片上; 必 片 上 

on-hook fifi 

on-line ” 连 线 

On-Line Analytical Processing( OLAP) ”联机 分 析 处 理 
on-line compiler 连 线 编译 需 
on-line processing ”联机 人 处理 
on-line system ”在 线 系统 

on-page access ”页 上 存 取 

one wait-state 一 个 等 候 状 态 
one-loop circuit 单 环 电路 

ones complement 二进制 反 码 
opaque “不 透明 

opaque body 不 透明 体 

open ”开启 ;开路 

open architecture ”开放 式 结构 

open source ”开放 资源 

open sources ” 源 代 人 码 开 放 

open system architecture ”开放 系统 结构 
open systems ”开放 系统 

operability ”操作 能 力 

Operating System(OS) 操作 系统 
operating voltage “作业 电压 
operation code( opcode) “运算 代码 
operational amplifier( opamp) “运算 放大 需 
optical disk 光盘 

optical drive ”光盘 机 

optical fiber ”光学 纤维 ;光纤 
optocoupler CRAT a 

orbit ”轨道 

oriented, object mH [HJ Xf A 
oriented, process 面 回 过 程 

out, first-in first-( FIFO) ”先进 先 出 
out, last-in first-(LIFO) “后进 先 出 
Output Input( L/O) 输入 输出 
overhead time ”开销 时 间 

overlap ĘĄ 

overlap angle Eff 

overload ”过 我 
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overwrite  & 755 ;复写 
overwrite error «E 7S fX ; 1 53 fu 


P 


package #38; FPR; HA; EET 
packaging density 封装 密度 
packaging level HRF 

packed data ”数据 信息 包 

packet {Af 

Packet Data Unit(PDU) 分 组 数据 单元 , 包 数 据 单元 
packet header 包 报 头 

packet layer protocol 信息 包 层 协定 
packet switching ”分 组 交换 

page access “分 页 存 取 

page attribute “分 页 属性 

page description language “页 摘 述 语言 
page fault 4} Ul FRIR 

page frame 分 页 框架 

page interleave 分 页 交错 

page space “页 空间 

page, graphic ”图 像 分 页 

page, logical 逻辑 分 页 

page, swapping out ”交换 出 分 页 
paging segment 分 页 分 段 

paging unit 分 页 单元 

paging, virtual ”虚拟 分 页 

palette i] FAR 

palette, color 彩色 调 色 板 

palette, true-color 真 色调 色 板 

pan HEER; WE BOCA 

panel 平板 ;面板 

panel, front ”面板 

parallel 平行; 并行 ;并 联 

parallel interface “并 行 接口 
parameter ”参数 

parity ”奇偶 

parity bit ”奇偶 位 

parity check ”奇偶 检测 
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partial ”部 分 

password “口令 ;密码 ;通行 密码 
path 通路 

pause 暂停 

pause frame fiii , Py Pr ti 
pay-TV 付费 电视 

payload AZLI 

peak ”峰值 

performance ”性 能 

performance optimization ”性 能 优化 
performance test ”性 能 测试 

period 周期 

period motion 周期 运动 

period, activation ”活化 期 
peripheral ”外 设 设备 

peripheral cell 外 设 存储 格 

perl programming language perl 程序 设计 语言 
Personal Computer( PC) 个 人 计算 机 
Personal Digital Assistant(PDA) 个 人 数字 助理 
physical layer protocol ”物理 层 协议 
piezoelectric EEK 

pipeline architecture ”管线 结构 
pipeline instruction ”管线 指令 
pipeline operation ”管线 作业 
pipeline processing ”管线 处 理 

pit Hi; ERa; t 

pitch $]; [B] FE 

pitch, dot ”点 路 

pitch, lead 引线 间距 

pixel 像素 

plane 平面 ; 层 

plotter 绘图 机 

polymorphism %4% 

port, dual- XX» O 

port, parallel ”平行 端口 

port, serial ím HO 

port, serial read FR £T Borg HO 
portability 可 移植 性 
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portable 可 移 接 ;手提 式 

Portable Appliance Tester( PAT) 便携式 电 天 检测 仪 
portable battery 手提 式 电池 

portable electronics ”便携式 电子 设备 

positive charge 1E frf 

positive electrode 1E Hif 

positive grid 正 栅 格 

power 功率 

power amplifier DRIK at 

power control ”功率 控制 

power, magnification ”放大 功率 

preamble transmission ”前 文 传送 

precision ”精准 

precision, double- Xf E 

precision, high ”高 精度 

primary address JF HEHE 

primary battery 原 电 池 

print head 打印 头 

printer 打印 机 

Printer Command Language(PCL) 打印 机 指令 语言 
Printer Description Language(PDL) 打印 机 描述 语言 
printer, daisy wheel 菊 轮 式 打 印 机 

printer, dot matrix ”点 阵 式 打印 机 

printer, impact 撞击 式 打 印 机 

printer, ink-jet 顺 墨 式 打 印 机 

printer, laser ”激光 打印 机 

printer, line 行 式 打 印 机 

printer, screen 丝 网 印刷 机 ;网 印 机 

printer, solder paste ” 焊 浆 打印 机 

printer, thermal ” 热 感 式 打印 机 

printing, ion-flow ”离子 流 打 印 

printing, near-letter quality ”优质 字符 打印 
programmable ”可 编程 

projectile ”抛射 体 

protective layer 保护 层 

protocol ”协议 

pulse ”脉冲 

Pulse Amplitude Modulation( PAM) 脉 幅 调制 
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pure tone ”纯音 
push-pull 1&3 3X ; JE 4X 
pushbutton ”按钮 


quad ”四 元 组 

quench detector 终止 检测 需 

query 咨询 

Query Processing Unit( QPU) 查询 处 理 单元 
queue “排列 


queue, code ”代码 排列 
quick sort ”快速 排序 


R 


Random Access Memory( RAM) 随机 存 取 存储 天 
Random Access Storage( RAS) 随机 存 取 存储 
raster 光栅 , 扫 摘 栅 , 网 板 , 屏 面 

raster graphics processor 光栅 图 像 处 理 需 

reaction 反应 

real image %43 

real-time interrupt SE H$ P Wr 

Real-Time Operating System( RTOS) 实时 作业 系统 
Real-Time Protocol(RTP) 实时 协议 

recognition, speech 语音 辨认 

recognition, voice ”声音 辨认 

recognizer, word | ^E ZH JA $& 

redundancy JRE ,元 码 码 ,元 余 , 多 余 
reflectance HPR 

refresh 更 新 

refresh cycle ”更 新 周期 

region 区域 

register, regular 规则 寄存 需 

register, segment |. 2] Ex 23 ffs 

register, serial $T ffe 

register, set A ff anl 

register, shift M 2f ff 2s 

relational database 关系 数据 库 

Relational Database Management System( RDBMS) 关系 数据 库 管 理 系 统 
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remote VCE 

remote enable/disable “远程 允许 /禁止 
Remote File Service( RFS) 远程 文件 服务 
Remote login(R-login) WIERK 
Remote Procedure Call RPC) ”远程 过 程 调用 
repeater ‘PAK AE 

repetition rate ER% 

repetitive E% 

replicated directory 复制 目录 

report 报表 

report generation ”报表 生成 

request 要求; 请 求 

request, interrupt( IRQ) Prk 
reservation ”保留 ; 预定 

reset 复位 

resource request 资源 请 求 

resource, shared- ”资源 分 享 

response time 反应 时 间 ; 响 应 时 间 
restore ”上 骨 存 入 ;还 原 

resume 恢复 

retrace ” 问 扫 

retrieve ”检索 ; 搓 取 

return [Eh ; 1% [n] 

ring, token ^A Xf 

rip 分割 ; 割 开 

robot ”机 知人 

robot arm ”机 械 辟 

rocker switch | SE FT 3T X 

rotator ”旋转 需 

router JH #ir 

routine ” 例 行 程序 

routing algorithm 路 由 算法 

routing control ”路 由 选择 控制 

row íT 

rule, generic ”通用 法 则 

run time ”运行 时 间 

Run-Length Limited(RLL) 游程 长 度 限 制 
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sample and hold 采样 和 保持 
sampling ”取样 

scalar 标量 

scalar product RFR 

scan fii 

scan path 扫描 路 径 

scan rate JH% 

scan, boundary ”边缘 扫 摘 

scan, double XX T4 

scan, raster ”光栅 扫描 

scanning, interlaced ”交织 扫描 ;隔行 扫描 
scanning, sequential ” 逐 行 扫 描 ; 顺 序 扫描 
scanning, vertical ”垂直 扫描 

scope “范围 

screen DEAE 

screen, fluorescent “荧光 幕 

search, binary tree ”二 元 树 状 搜寻 
search, comparative ”比较 式 搜寻 
search, distributive ”分 配 式 搜寻 
search, external ”外 部 搜寻 

search, internal ”内 部 搜寻 

search, linear 线性 搜寻 

search, sequential ”顺序 搜寻 

second, byte-per-” 每 秒 字 市 数 
second, million instructions per( MIPS) ”每 秒 百 万 条 
secondary output 二 次 输出 ;次 级 输出 
section | [X Ez 

segment 分 段 

segment address ”分 段 地 址 

segment offset 分 段 偏 移 

segment register SELATA 
segment, code ”代码 分 段 

segment, paging ”分 页 分 段 
semiconductor 半导体 

sensor [£g 

sensor, image “影像 感应 天 


= 
“> 
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separator, encoder/decoder data  fmfijg/ MEID as BE OP a os 
sequence 序列 

sequential list ”顺序 列 

sequential mapping ”顺序 映射 

serial $47 

serial adapter “B77 ACERS 

serial bit $TM 

Serial-In Serial-Out (SISO) 串 入 串 出 

server [KA ds 

server, disk ”磁盘 服务 天 

server, file 文件 服务 需 

server, network ”网 络 服务 前 

service, bulletin board( BBS) ”电子 布告 板 服务 
service, remote file( RFS) ”远程 文件 服务 
Services Switching Point( SSP) ”业务 交换 点 
Serving GPRS Support Node( SGSN) GPRS 业务 支撑 点 
session XJ if 

Session Initiation Protocol( SIP) ” 话 路 启动 协议 
session layer ine 

set 46 

set instruction ”指令 集 

set, character ”字符 集 

set-top box ”机顶盒 

shadow ”阴影 

shielding ”屏蔽 

short 短路 

short circuit ”短路 

shutdown ”停机 

shutter ”快门 

signal processing ”信号 处 理 

simulate ”模拟 

slot 间 际 ; 磁 格 ; 槽 口 

Small-Scale Integration( SSI) ”小 规模 集成 
smart sensor 智能 传 感 需 

socket 插座 

soft state ” 软 状 态 

software ”软件 

software library 软件 库 
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software portability 软件 可 移植 性 
software repository 软件 存储 库 
software reusability 软件 可 复 用 性 
software tool ”软件 工具 

software trigger ”软件 触发 

sort, comparative ”比较 式 排 序 
sort, distributive “分 配 式 排序 
external ”外 部 排序 

insertion ”插入 式 排 序 
interchange ”交换 式 排 序 

sort, internal ”内 部 排序 

sort, merge 合并 式 排序 

sort, partition exchange ”划分 交换 式 排序 
sort, selection ”选择 式 排序 
sound spectrum if 


sort 


E 


sort 


u 


sort 


EJ 


u 


sound speed 声速 
source code Jf 5 
source file JR xc ft 
spanning tree algorithm 生成 树 算 法 
spectrum, sound ” 声 谱 
speech recognition ”语音 识别 
speech synthesizer 语音 合成 需 
speed ”速度 
stack ”堆栈 
stack register 暂 存 堆栈 大 
star connection ” 星 状 连接 
star network ÆJ RA 
star network topology 星 状 网 络 拓扑 
state diagram ”状态 图 
state, initial 初始 状态 
state, logic ”逻辑 状态 
state, steady- ”稳定 状态 
state, wait ”等 候 状 态 
statement ” 述 句 ;陈述 
statement, conditional ”条件 式 述 句 
station, network ”网 络 站 
station, single-attached( SAS)” 单 配 附 传 讯 站 
status ”状态 
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status bit ”状态 位 

status byte AE 

storage bit 存储 位 

storage class ”存储 类 别 
storage temperature ”存储 温度 
stream Œ; Tit 

string AB 

structural analysis ”结构 分 析 
structure, tree 树 状 结 构 
structure, user 用户 结构 
sub-addressing ”了 于 地 址 寻 址 ,了 于 寻 址 
sub-band coding “和子 市 编码 
subnet 子 网 

subphase FTE: 

subroutine ” 子 程 序 , 子 例 行 程序 
subset TÆ 

subsystem FA 

subsystem bus FRAT 
superset ” 超 集 


T 


table 列表 ; 表 
table, file allocation( FAT) 文件 配置 表 
table, index “索引 表 
table, truth H(A 
Tagged Image File Format( TIFF) 已 标记 图 像 文 件 格式 (由 Aldus 和 Microsoft 联合 
开发 ) 
tangent 正切 ;切线 
tape, cassette FIt 
telecom 电信 ,电讯 , 远 距 离 通 信 
telecommunication service ”电信 业务 ;(ISDN ) B HIP 2X 9i MV F 
teleconferencing ”远程 会 议 ,电话 会 议 
template ”样板 ;模板 
terminal 终端 
Terminal Adapter( TA) 终端 配 接 需 
terminal mode ”终端 方式 
terminal server ZX ym lt A os 
terminal voltage ”终端 电压 
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terminal, data ”数据 终端 机 
terminal, intelligent 智能 型 终端 机 
terminal, keyboard PEREIRA vm pL 
time trigger 时 间 触 发 大 
timing analysis ”定时 分 析 , 时 序 分 析 
timing constraint 定时 限制 
timing data ”定时 数据 
timing delay 定时 延迟 
timing diagram 定时 图 
token | 28 ; BUE 
Token Bus Controller( TBC) SMEA E itil 45 
token bus network | ^ Jf 3 £X pv] 
token ring 令 牌 环 
token ring switch 今 牌 环 交 换 
tone 色调 ;音调 
tone, dual 音调 
tone, fundamental 基 音 
tone, pure ”纯音 
topological inversion ”拓扑 式 转换 
topological mapping ”拓扑 映射 
topology 拓扑 ,拓扑 学 
touch screen fh Tz BE EE 
trace JE ER ; Ze yl 
transform Æ fh 
transform operation ”变换 操作 
transformation, discrete “离散 变换 
transition ”转换 ;变换 
transition time ”转换 时 间 
translation ”翻译 ;转换 
Transmission Control Protocol( TCP) ”传输 控制 协议 
Transmission Control Protocol/Internet Protocol( TCP/IP) ”传输 控制 / 跨 网 协议 
transmission layer 传输 层 
transmission, digital ”数字 传输 
transmission, serial 串 行 传输 
transmission, synchronous 同步 传输 
transparent ”透明 
transport layer 传送 层 
transpose matrix $ EIER 
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tree 树 

tree network topology 树 状 网 拓扑 [技术 | 
tree structure ” 树 状 结构 

truth table SAK 

tube, cathode ray( CRT) 阴极 射线 管 
tube, vacuum ”真空管 


type, bus ”总 线 类 型 


undefined 未 定义 的 

unidirection F[n] 

Uniform Resource Locator(URL) 统一 资源 定位 符 , 统 一 资源 定位 需 
Uniform Resource Name( URN) 统一 资源 名 
unit 单位 ;单元 

unit, binary “二进制 单元 

unit, bus control ”总 线 控制 单元 

unit, cache jay RARE ia AS OC 

unit, central processing(CPU) 中 央 处 理 需 
unit, paging ”分 页 单元 

universal 通用 

universal ADSL 通用 ADSL 

universal buffer iH HÆ zs 

universal counter 通用 计数 需 

Universal Synchronous Bus( USB) 通用 同步 总 线 
upgrade ”升级 

usability 可 用 性 

user 用 户 

user interface 用户 接口 ,用户 界面 

user, end 2X xg; H] P? 

user-defined ”用 户 定 义 

utility ”实用 程序 

utility bus ”公用 总 线 


vacant code %44 

vacuum tube 真空管 

valid 有 效 

valid memory address ”有效 存储 需 地 址 
validation ”确认 
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value ”数值 ;价值 

vector RE , [n] tt 

vector product [8] Ht fH 

vector resolution — [n] tA} fff 

vector sum . 问 量 和 

velocity 速度 

verification ”验证 

verification system “验证 系统 

vertex ”顶点 

vertical ”垂直 的 

Very High Scale Integrated Circuit( VHSIC) 超 高 规模 集成 电路 
Very Large Scale Integrated circuit( VLSI) 超大 规模 集成 电路 
video amplifier wi Ht 

video attribute ”视频 属性 

video codec ”视频 编 解码 各 , TIUS Zi VEO at 

video converter 视频 转换 六 

video database ”视频 数据 库 

virtual ”虚拟 

virtual circuit ”虚拟 电路 

virtual reality 虚拟 现实 

Virtual Reality Modeling Language( VRML) ”虚拟 现实 建 模 语 言 
virus ”病毒 ;计算 机 病毒 

volume 容量 ; 声 量 

volume control J= tE F% iil 


wait state ”等 候 状 态 

wait-state controller SARIRA d ilg 
wait-state generator SARIRA ^E gi 
warm-up time . TjtZAmT A] 

warning 4 

watchdog = Hi a at 

waterproof ”防水 的 

watertight 不 汤水 的 ,不 透水 的 

watt (W) 瓦特 

watt-hour (Wh) 瓦特 小 时 
What-You-See-What-You-Get( WYSWYG) 所 见 即 所 得 
Wide Area Network( WAN) 和 宽 域 性 网 络 
wide band ”宽频 带 
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wide, byte- [7595 

window ”视窗 

window size ”视窗 尺寸 ,窗口 尺寸 
window, register Aff du tl fa 

wire 金属 线 

wireless ”无 线 

wireless LAN 无 线 区 域 性 网 络 

word 字 ; 字 组 

word interleaving ” 字 交 织 , 字 交错 
workstation 工作 站 

World Wide Web( WWW) 全 球 互 联网 
worm ”蠕虫 程序 (在 因特网 上 自动 运行 的 一 种 程序 ) 
wow 摇晃 

wrap #2 

wrap-around ”环绕 

write BA 

write access 45 Aff Hx 

write buffer “5 AZ pgs 

write cache 5 A 3X e x 2 PUER fita 
write cycle 写 人 周期 


X-ray spectrum X 射线 谱 
x-y recorder x-y 记录 仪 
xDSL 各 种 效 字 用 户 线 


yoke “磁头 组 

Y connection YY 连接 

Y network YY 网络 

Y-T display Y-T 显示 

Y-address Y- 地 址 

Y-connected circuit 星 状 连接 电路 


Z 


Z modem 在 调制 解 调 需 链 路 上 传输 文件 的 一 种 方法 ,可 上 自动 调整 传输 速率 
Z-address Z 地 址 
Z-axis amplifier Z AIC às 
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附录 E LHS SypREWRAEK 


随 着 中 国 改 革 开 放 的 不 断 深 入 ,参与 国际 化 事务 日 益 频 繁 ,对 外 贸易 不 断 深 化 ,我 国 
对 大 学 生 英 语 的 学 习 日 益 重 视 。 与 此 同时 , 随 着 企业 国际 交流 的 频繁 ,外 包 行 业 的 兴起 ， 
技术 的 快速 发 展 ,社会 对 工科 学 生 的 专业 英语 提出 了 迫切 需求 。 

2007 年 ,教育 部 网 站 公布 了 “大 学 英语 课程 要 求 ” ,其 中 “教学 要 求 ”" 中 指出 了 大 学 阶 
段 的 英语 教学 要 求 分 为 3 个 层次 , 即 一 般 要 求 较 高 要 求 和 更 高 要 求 。 大 学 英语 课程 的 设 
计 应 充分 考虑 听 .说 能 力 培养 的 要 求 ,并 给 予 足够 的 学 时 和 学 分 ;应 大 量 使 用 先进 的 信息 
技术 ,开发 和 建设 各 种 基于 计算 机 和 网 络 的 课程 ,为 学 生 提 供 良 好 的 语言 学 习 环 境 与 


条 件 。 
1. 一 般 要 求 


(1) 听力 理解 能 力 : 能 听 懂 英语 授课 ,能 听 懂 日 常 英语 谈话 和 一 般 性 题材 的 讲座 ,能 
听 懂 语 速 较 慢 ( 每 分 钟 130 ~ 150 词 ) 的 英语 广播 和 电视 节目 ,能 和 擎 握 其 中 心 大 意 , 抓 住 要 
点 。 能 运用 基本 的 听力 技巧 。 

(2) 口语 表达 能 力 : 能 在 学 习 过 程 中 用 英语 交流 ,并 能 就 某 一 主题 进行 讨论 ,能 就 日 
党 话题 用 英语 进行 交谈 ,能 经 准备 后 就 所 熟悉 的 话题 作 人 简短 发 言 ,表达 比较 清楚 ,语音 n 
调 基 本 正确 ,能 在 交谈 中 使 用 基本 的 会 话 策略 。 

(3) 阅读 理解 能 力 : 能 基本 读 懂 一 般 性 题材 的 英文 文章 ,阅读 速度 达到 每 分 钟 70 
词 。 在 快速 阅读 篇 幅 较 长 ,难度 略 低 的 材料 时 ,阅读 速度 达到 每 分 钟 100 词 。 能 就 阅读 材 
料 进行 略 读 和 寻 读 。 能 借助 词典 阅读 本 专业 的 英语 教材 和 题材 熟悉 的 英文 报刊 文章 ,向 
握 中 心 大 意 , 理 解 主要 事实 和 有 关 细 方 。 能 读 懂 工作 、 生 活 中 常见 的 应 用 文体 的 材料 ,能 
在 阅读 中 使 用 有 效 的 阅读 方法 。 

(4) 书面 表达 能 力 : 能 完成 一 般 性 写作 任务 ,能 描述 个 人 经 历 、 观 感情 感 和 发 生 的 
事件 等 ,能 写 常见 的 应 用 文 ,能 在 半 小 时 内 就 一 般 性 话题 或 提纲 写 出 不 少 于 120 词 的 短 
文 , 内 容 基 本 完整 ,中 心思 想 明 确 , 用 词 恰当 ,语意 连贯 ,能 和 车 握 基本 的 写作 技能 。 

(5) 翻译 能 力 : 能 借助 词典 对 题材 熟悉 的 文章 进行 英汉 互 译 ,英汉 译 速 为 每 小 时 约 
300 个 英语 单词 , 汉 英 译 速 为 每 小 时 约 250 个 汉字 。 译 文 基本 准确 ,无 重大 的 理解 和 语言 

(6) 推荐 词汇 量 : 掌握 的 词汇 量 应 达到 约 4795 个 单词 和 700 个 词组 ( 含 中 学 应 掌握 
的 词汇 ) ,其 中 约 2000 个 单词 为 积极 词汇 , 即 要 求学 生 能 够 在 认 知 的 基础 上 在 口头 和 书面 
表达 两 个 方面 熟练 运用 的 词汇 。 


2. 较 高 要 求 


(1) 听力 理解 能 力 : 能 听 懂 英语 谈话 和 讲座 ,能 基本 听 懂 题材 熟悉 .篇 幅 较 长 的 英语 
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广播 和 电视 节目 , 语 速 为 每 分 钟 150 ~ 180 词 ,能 掌握 其 中 心 大 意 , 抓 住 要 点 和 相关 细节 , 
能 基本 听 懂 用 英语 讲授 的 专业 课程 。 

(2) 口语 表达 能 力 : 能 用 英语 就 一 般 性 话题 进行 比较 流利 的 会 话 ,能 基本 表达 个 人 
意见 .情感 和 观点 等 ,能 基本 陈述 事实 理由 和 描述 事件 ,表达 清楚 ,语音 .语调 基本 正确 。 

(3) 阅读 理解 能 力 : 能 基本 读 懂 英语 国家 大 众 性 报刊 杂志 上 一 般 性 题材 的 文 草 , 阅 
读 速 度 为 每 分 钟 70 ~90 词 。 在 快速 阅读 篇 幅 较 长 难度 适中 的 材料 时 ,阅读 速度 达到 每 
分 钟 120 词 。 能 阅读 所 学 专业 的 综述 性 文献 ,并 能 正确 理解 中 心 大 意 , 抓 住 主要 事实 和 有 
关 细 节 。 

(4) 书面 表达 能 力 : 能 基本 上 就 一 般 性 的 主题 表达 个 人 观点 ,能 写 所 学 专业 论文 的 
英文 摘要 ,能 写 所 学 专业 的 英语 小 论文 ,能 描述 各 种 图 表 , 能 在 半 小 时 内 写 出 不 少 于 160 
词 的 短文 ,内 容 完 整 ,观点 明确 ,条 理 清楚 ,语句 通顺 。 

(5) 翻译 能 力 : 能 摘 译 所 学 专业 的 英语 文献 资料 ,能 借助 词典 翻译 英语 国家 大 众 性 
报刊 上 题材 熟悉 的 文章 ,英汉 译 速 为 每 小 时 约 350 个 英语 单词 , 汉 英 译 速 为 每 小 时 约 300 
个 汉字 。 译 文通 顺 达 意 , 理 解 和 语言 表达 错误 较 少 ,能 使 用 适当 的 翻译 技巧 。 

(6) 推荐 词汇 量 : 掌握 的 词汇 量 应 达到 约 6395 个 单词 和 1200 个 词组 (包括 中 学 和 
一 般 要 求 应 该 掌握 的 词汇 ) ,其 中 约 2200 个 单词 (包括 一 般 要 求 应 该 掌握 的 积极 词汇 ) 为 
积极 词汇 。 


3. 更 高 要 求 


(1) 听力 理解 能 力 : 能 基本 听 公 英语 国家 的 广播 电视 节目 ,车 握 其 中 心 大 意 , 抓 住 要 
点 。 能 听 民 英语 国家 人 士 正常 语 速 的 谈话 ,能 听 民 用 英语 讲授 的 专业 课程 和 英语 讲座 。 

(2) 口语 表达 能 力 : 能 较为 流利 .准确 地 就 一 般 或 专业 性 话题 进行 对 话 或 讨论 ,能 用 
简练 的 语言 概括 篇 幅 较 长 有 一 定语 言 难度 的 文本 或 讲话 ,能 在 国际 会 议和 专业 交流 中 宣 
读 论文 并 参加 讨论 。 

(3) 阅读 理解 能 力 : 能 读 懂 有 一 定 难度 的 文章 ,理解 其 主旨 大 意 及 细节 ,能 阅读 国外 
英语 报刊 杂志 上 的 文章 ,能 比较 顺利 地 阅读 所 学 专业 的 英语 文献 和 资料 。 

(4) 书面 表达 能 力 : 能 用 英语 撰写 所 学 专业 的 简短 的 报告 和 论文 ,能 以 书面 形式 比 
较 自 如 地 表达 个 人 的 观点 ,能 在 半 小 时 内 写 出 不 少 于 200 词 的 说 明文 或 议论 文 ,思想 表达 
清楚 ,内容 丰富 , 文 草 结 构 清晰 ,逻辑 性 强 。 

(5) 翻译 能 力 : 能 借助 词典 翻译 所 学 专业 的 文献 资料 和 英语 国家 报刊 上 有 一 定 难度 
的 文章 ,能 翻译 介绍 中 国 国 情 或 文化 的 文章 。 喘 汉 详 速 为 每 小 时 约 400 个 英语 单词 , 汉 英 
译 速 为 每 小 时 约 350 个 汉字 。 译 文 内 容 准 确 , 基 本 无 错 详 漏 译 ,文字 通顺 达意 ,语言 表达 
错误 较 少 。 

(6) 推荐 词汇 量 : 掌握 的 词汇 量 应 达到 约 7675 个 单词 和 1870 个 词组 (包括 中 学 一 
般 要 求 和 较 高 要 求 应 该 掌握 的 词汇 ,但 不 包括 专业 词汇 ) ,其 中 约 2360 个 单词 为 积 
词汇 。 
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附录 部 分 答案 
Unit 1 


[Ex] 】 根 据 诛 文 内 容 回答 问题 : 

(1) A general purpose computer has four main components; the arithmetic logic unit 
( ALU) , the control unit, the memory, and the input and output devices ( collectively termed 
LIZO ) . 

(2) The control unit, ALU, registers, and basic I/O (and often other hardware closely 
linked with these) are collectively known as a central processing unit ( CPU). 

(3) The control unit ( often called a control system or central controller) manages the 
computer's various components; it reads and interprets ( decodes) the program instructions, 
transforming them into a series of control signals which activate other parts of the computer. 

(4) The ALU is capable of performing two classes of operations; arithmetic and logic. 

(5) On a typical personal computer, peripherals include input devices like the keyboard 
and mouse, and output devices such as the display and printer. Hard disk drives, floppy disk 
drives and optical disc drives serve as both input and output devices. Computer networking is 
another form of I/O. 


【Ex2 ] 把 下 列 句 子 翻译 成 中 文 : 

Wi 

[ Ex3 ] 选择 适当 的 答案 填空 : 

(1) A (2) € (3) D (4) C (5) A 
Unit 2 


[ Ex1 ] 根据 诛 文 内 容 回答 问题 : 

(1) C is a computer programming language. That means that you can use C to create 
lists of instructions for a computer to follow. 

(2) Stderr is a special UNIX file which serves as the channel for error messages. 

(3) The body of the function is bounded by a set of curly brackets. 

(4) They are integer values,floating point values and single character values. 

(5) The way your program remembers things is by using variables. 

[ Ex2 】 把 下 列 句 子 翻译 成 中 文 : 

(1) 严谨 的 程序 确保 了 边界 条 件 是 正确 的 。 

(2) 括号 里 包含 了 参数 和 它们 的 类 型 ,用 逗号 分 隔 。 

(3) 该 示例 函数 可 以 被 为 一 函数 的 一 行 语句 调用 ,该 行 语句 看 过 去 像 这 样 。 

(4) 函数 体 用 一 对 大 括号 分 开 。 
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(5) 这 是 printf 语句 的 变量 ,fprintf 输出 语句 将 它 的 输出 发 送 到 一 个 文件 。 

(6) 标准 输出 文件 是 一 个 作为 错误 信息 通道 的 特殊 UNIX 文件 。 

(7) 即使 该 程序 的 正常 输出 被 重 定 癌 到 一 个 文件 或 打印 机 ,发 送 到 标准 输出 文件 的 
消息 也 将 出 现在 屏幕 上 。 

(8) 这 句 是 调用 Power 函数 ,并 将 返回 值 赋值 给 result 变量 。 

【 Ex3] 选择 适当 的 答案 填空 ; 

(1) B (2) A (3) A (4) A (5) C 


Unit 3 


【Exl 】 根 据 诛 文 内 容 回答 问题 : 

(1) Discrete Mathematics is the general term for several branches of mathematics, 
which is based on the study of mathematical structures that are fundamentally discrete rather 
than continuous. 

(2) Research in discrete mathematics increased in the latter half of the twentieth century 
partly due to the development of digital computers which operate in discrete steps and store 
data in discrete bits. 

(3) The topics in Discrete Mathematic are Theoretical computer science, Mathematical 
logic, Set theory, Graph theory, Operation research, Topology. 

(4) Logical formulas are discrete structures, as are proofs, which form finite trees or, 
more generally, directed acyclic graphstructures. 

(5) Operations research techniques include linear programming and other areas of 
optimization, queuing theory, scheduling theory, network theory. Operations research also 
includes continuous topics such as continuous-time Markov process, continuous-time 
martingales, process optimization, and continuous and hybrid control theory. 

【Ex2]】 把 下 列 句 子 翻 详 成 中 文 . 

(1) 图 论 是 一 门 有 许多 现代 应 用 的 古老 学 科 。 

(2) 集合 的 元 素 之 间 的 关系 被 表示 成 一 种 结构 ,这 种 结构 叫 作 关系 。 

(3) 离散 数学 的 不 少 内 容 是 研究 用 于 表示 离散 对 象 的 离散 结构 。 

(4) 离散 数学 是 通 回 所 有 数学 学 科 高 级 许 程 的 必 经 之 路 。 

(5) 计算 机 芯片 主要 负责 执行 指令 。 

(6) 磁带 必须 顺序 读 写 ,不 能 随机 读 写 。 

(7) 可 以 通过 点 击 选 定 文本 之 外 的 任何 地 方 或 按 任 一 方向 键 取消 选 定 。 

(8) 单个 的 USB 接口 比 许多 并 口 速度 快 , 它 还 可 以 无 需 端 接 带 而 链接 许多 设备 。 

【 Ex3 ] 选择 适当 的 答案 填空 : 

(1) D (2) B (3) C (4) DA 


Unit 4 


[ Ex1 】 根 据 诛 文 内 容 回答 问题 
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(1) A software process is a set of activities that leads to the production of a software 
product. 

(2) They are Software specification, Software design and implementation, Software 
validation and Software evolution. 

(3) Software processes can be improved by process standardisation where the diversity 
in software processes across an organisation is reduced. 

(4) Because of the costs of produdng and approving documents, iterations are costly 
and involve significant rework. Therefore, after a small number of iterations, it is nonnal to 
freeze parts of the development. 

(5) Errors and omissions in the original software requirements are discovered. Program 
and design errors, emerge and the need for new functionality is identified. The system must 
therefore evolve to remain useful. 

[ Ex2 】 把 下 列 句 子 翻译 为 中 文 : 

(1) 一 个 软件 过 程 是 一 组 引发 软件 产品 生产 的 活动 。 

(2) 由 于 需要 判断 和 创造 力 , 所 以 软件 过 程 日 动 化 的 尝试 只 获得 了 有 限 的 成 功 。 

(3) 计算 机 辅助 软件 工程 (CASE ) 工 具 的 有 效 性 受到 限制 ,其 中 一 个 原因 是 软件 过 
程 具有 极 大 的 差异 性 。 

(4) 对 于 业务 系统 ,由 于 需求 变更 频繁 ,所 以 采用 一 个 灵活 .敏捷 的 过 程 可 能 更 有 效 。 

(5) 软件 过 程 模型 是 软件 过 程 的 抽象 表示 法 。 

(6) 系统 开发 过 程 主要 是 把 这 些 组 件 集成 到 新 系统 中 ,而 非 从 头 开发 。 

(7) 在 这 个 阶段 ,软件 设计 是 作为 一 组 程序 或 程序 单元 实现 的 。 

(8) 瀑布 模型 的 优势 在 于 它 在 每 个 阶段 都 生成 文档 ,而 且 它 与 其 他 工程 过 程 模型 


一 致 。 
【Ex3 ] 选择 适当 的 答案 填空 : 
(1) B (2) € (3) D (4) B (5). C 
Unit 5 


[ Ex1 ) 根据 诛 文 内 容 十 空 : 

(1) system (2) manipulates (3) capability (4) conflict (5) execute 

【Ex2 ] 把 下 列 句 子 翻译 成 中 文 : 

(1) MySQL 数据 库 系 统 使 用 的 是 客户 端 / 服 务 器 架构 ,这 种 架构 以 服务 器 为 中 心 。 
服务 需 是 真正 操作 数据 库 的 程序 。 

(2) 服务 需 是 真正 操作 数据 库 的 程序 ,客户 端 不 直接 对 其 操作 。 

(3) MySQL 是 与 生 俱 来 的 网 络 数据 库 系 统 ,所 以 ,客户 端 能 和 运行 在 本 地 机 上 的 或 
者 运行 在 其 他 地 方 的 服务 融通 信 。 

(4) 这 样 ,一 个 客户 疹 是 一 个 包括 在 MySQL 分 布 的 MySQL 程序 。 

(5) MySQL 同时 也 能 使 用 在 非 交 互 方式 。 例 如 ,从 文件 或 者 其 他 程序 阅读 语句 。 

(6) 这 使 你 能 从 脚本 内 或 者 时 钟 守护 作业 里 ,或 者 连接 到 其 他 应 用 程序 使 用 
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MySQL. 
(7) 为 一 个 流行 接口 是 phpMyAdmin, T BE LE HT) 38 zl NN 9 28 UjIR] MySQL, 
(8) 在 这 种 情况 下 ,一 些 原则 可 能 不 同 ,如 结束 SQL 语句 的 方式 。 
【 Ex3 】 选 择 适 当 的 答案 填空 : 
(1) A (2) A (3) B (4) D (5) C 


Unit 6 


【 Ex] 根据 课文 内 容 填 空 . 

(1) unmanned (2) probes (3) computexized (4) fight (5) lives 

【Ex2 把 下 列 句 子 翻译 成 中 文 : 

(1) 一 个 欧 入 式 系统 就 是 一 个 计算 机 人 硬件 和 软件 的 集合 体 ,也 许 还 包括 其 他 一 些 机 
械 部 件 , 它 是 为 完成 某 种 特定 的 功能 而 设计 的 。 

(2) 在 整个 80 年 代 , 藤 入 式 系 统 静 悄悄 地 统治 着 微 处 理 融 时 代 , 并 把 微 处 理 需 带 和 人 
了 我 们 个 人 和 职业 生活 的 每 一 个 角落 。 

(3) 例如 ,如 果 一 个 实时 系统 是 飞机 飞行 控制 系统 的 一 部 分 ,那么 一 个 延 时 计算 就 可 
能 使 乘客 和 机 组 人 员 的 生命 受到 威胁 。 

(4) 硬件 从 一 组 电 连 接 上 读 取 数字 信号 ,然后 转换 成 模拟 信和 号, 传 到 相连 的 电话 
线 上 。 

(5) 如 果 你 很 笠 运 ,硬件 所 市 的 文档 中 会 有 你 所 需要 的 一 整套 方 框图 。 

(6) 如 果 你 从 这 个 角度 想 ,很 快 就 会 发 现 处 理 角 有 很 多 。 

(7) 外 设 不 仅 是 简单 的 存储 传 给 它 的 数据 ,而 是 把 它 翻译 成 一 条 命令 或 者 翻译 成 以 
某 种 方式 处 理 的 数据 。 

(8) 已 经 有 很 多 具有 巨大 市 场 浴 力 的 新 的 散人 式 设 备 了 : 可 以 被 中 央 计 算 机 控制 的 
调 光 天 和 恒温 硕 , 当 有 小 孩 或 禾 个 子 的 人 在 时 ,智能 气 宫 不 会 充气 ,掌上 电子 记事 短 和 个 
人 数字 助理 (PDA) .数码 照相 机 和 仪表 导航 系统 。 

【 Ex3 】 选 择 适 当 的 答案 填空 ; 

(1) B (2) A (3) D (4) B (5) € 


Unit 7 
[ Ex1 RAS TROC PAL ISTA TREE: 


(1) The Internet Protocol Suite is the set of communications protocols used for the 
Internet and other similar networks. 

(2) The Transmission Control Protocol ( TCP) and the Internet Protocol ( IP). 

(3) The TCP/IP model consists of four layers. From lowest to highest, these are the 
Link Layer, the Internet Layer, the Transport Layer, and the Application Layer. 

(4) In the early 1970s. 

(5) An application uses a set of protocols to send its data down the layers, being further 
encapsulated at each level. 
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[ Ex2 ] 把 下 列 句 子 翻 译 成 中 文 : 

(1) 因特网 协议 组 是 一 组 实现 支持 因特网 和 其 他 类 似 网 络 运 行 的 网 络 传输 协议 。 

(2) 更 上 层 越 逻辑 化 地 接近 使 用 者 ,用 于 处 理 比较 抽象 的 数据 , 它 依 赖 低层 协议 将 数 
据 翻 译 成 最 终 能 在 物理 上 传输 的 形式 。 

(3) 因特网 协议 起 源 于 1970 年 早期 的 国防 高 级 研究 项 目 机 构 (DARPA ) 进行 的 研究 
和 开发 。 

(4) 1978—1983 年 , 几 种 TCP/IP 原型 在 多 个 研究 中 心 进行 开发 。 

(5) TCP/IP 协议 组 通过 封装 提供 抽象 协议 和 服务 。 

(6) 这 一 个 模型 并 不 希望 成 为 一 个 严格 的 参考 模型 ,并 要 求 新 协议 以 它 为 标准 。 

(7) 在 当今 使 用 的 大 部 分 操作 系统 中 ,包括 所 有 的 用 户 系统 ,都 含有 TCP/IP 实现 。 

(8) 大 部 分 的 IP 实现 ,程序 员 可 通过 使 用 套 接 字 (使 用 的 也 可 以 是 其 他 协议 ) 和 合 
适 的 应 用 接口 (API) 功能 完成 。 

【 Ex3 】 选 择 适 当 的 答案 填空 : 

(1) B (2) C (3) D (4) C (5) A 


Unit 8 


[ Ex1 HR E TR XC AI KA [n] ; 

(1) Array; Quick insertion, very fast access if index known while Slowing search, 
slowing deletion, fixed size. 

(2) Binary tree: Quicking search, insertion, deletion (if tree remains balanced) while 
Deleting algorithm is complex. 

(3) Algorithm is a method to make search, insert,delete a item more effectively. 

(4) Procedural programs are organized by dividing the code into functions, so when 
several functions needed to access the same data,it is easy to bring troubles. 

(5) Every entity in our real word can be seems as an object. Objects of the same type can 
be called a class when you need to look up tens of thousands of items in less than a second. 

[ Ex2 】 把 下 列 句 子 翻译 成 中 文 : 

(1) 基于 Java 的 数据 结构 与 算法 是 把 数据 处 理 成 你 想 要 的 方式 存储 的 最 实用 的 
A X. 

(2) 迭代 的 观点 对 设计 具体 的 算法 非常 重要 。 

(3) 多 组 函数 可 以 形成 更 大 的 单元 ,被 称 为 模块 或 文件 。 

(4) 程序 中 的 对 象 不 仅 与 现实 中 的 对 象 对 应 得 更 加 准确 ,而 且 还 能 解决 过 程 处 理 模 
型 中 全 局 变量 存在 的 隐患 。 

(5) 程序 中 的 全 局 变量 可 以 不 受 限制 地 被 任意 函数 访问 。 

(6) 链表 可 能 是 继 数组 之 后 用 得 最 广泛 的 数据 存储 结构 。 

(7) 链表 是 一 种 灵活 的 存储 机 制 ,适用 于 多 种 通用 数据 库 。 

(8) 对 某 些 哈 硕 表 来 说 ,如 果 表 满 了 ,性 能 将 严重 下 降 。 

【Ex3 ] 选择 适 当 的 答案 填空 . 
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(1) C (2) B (3) A (4) A (5) B 
Unit 9 


[ Ex1] 根据 课文 内 容 填 空 

(1) prohibits (2) restriction (3) generates (4) enthusiast (5) appropriate 

【Ex2 把 下 列 句 子 翻译 成 中 文 : 

(1) MSDN 是 微软 生产 的 一 部 分 (产品 ) , 它 负责 处 理 公司 开发 人 员 与 测试 人 员 的 关 
系 ,因为 便 件 开发 人 员 感 兴趣 的 是 操作 系统 ,而 开发 人 员 面 对 的 是 各 个 操作 系统 的 平台 ， 
开发 人 员 利 用 API 及 微软 的 应 用 程序 脚本 语言 。 

(2) 当 鲍 勃 离开 MSDN 时 ,丹尼斯 克 雷 恩 博 士 接手 了 他 的 工作 任务 ,并 对 所 负责 的 
栏目 增加 了 一 些 幽 默 元 素 。 

(3) 组 件 是 IComponent 接口 的 默认 实现 ,并 作为 在 公共 语言 运行 库 的 所 有 组 件 的 

(4) 在 这 种 情况 下 ,你 可 以 从 AsyncCompletedEventArgs 类 派生 上 自己 的 类 ,在 派生 类 
中 增加 私有 实例 变量 和 相应 的 只 读 公 有 属性 。 

(5) System. ComponentModel 命名 空间 提供 了 一 些 用 于 实现 运行 时 和 设计 时 的 组 件 
和 控件 行为 的 类 。 

(6) MSDNAA 账户 不 是 MSDN 的 账户 ,不 能 用 来 访问 MSDN 网 站 订阅 者 的 内 容 或 
下 载 部 分 。 

(7) 总 的 来 说 , 它 是 一 个 很 好 的 一 平台 ,通过 该 平台 可 以 正确 处 理 所 有 的 MSDN 
任务 。 

(8) 如 果 你 添加 了 System. ComponentModel. AsyncCompletedEventHandler 委托 的 事 
件 实例 。 

(1) A (2) D (3) B (4) D (5) C 


Unit 10 


[Ex] ) 根据 诛 文 内 容 十 空 : 

(1) complex (2) yielding (3) execute (4) parallel (5) magnitude 

【Ex2 把 下 列 句 子 翻 详 成 中 文 : 

(1)“ 优 化 ”这 一 术语 在 编译 融 设 计 中 是 指 编译 右 尝 试 生成 比 一 般 代码 更 高 效 代码 
的 行为 。 

(2) 在 现代 社会 ,编译 带 所 做 的 代码 优化 日 益 重 要 和 复杂。 

(3) 事实 上 ,我 们 针对 编译 项 优化 提出 的 大 多 数 问题 都 是 不 可 判定 的 。 

(4) 我 们 需要 对 程序 的 行为 完全 了 解 后 才能 开始 ,而 且 要 有 全 面 的 测试 和 评估 验证 
我 们 的 直觉 。 

(5) 优化 必须 正确 ,也 就 是 说 ,要 和 被 编译 程序 原来 的 功能 一 致 。 

(6) 优化 必须 提高 许多 程序 的 性 能 。 
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(7) 编译 时 间 必 须 合 理 。 
(8) 如 果 生 成 的 代码 不 必 正 确 , 那 么 编写 一 个 能 生成 快速 代码 的 编译 磊 就 是 很 简单 
的 事情 了 。 
【 Ex3 选择 适当 的 答案 填空 
A 


(1) A (2) (3) B (4) C (5) A 


Unit 11 


[ Ex1 ] 根据 诛 文 内 容 回答 问题 : 

(1) An operating system is software, consisting of programs and data that runs on 
computers and manages the computer hardware and provides common services for efficient 
execution of various application software. 

(2) Including batch processing, input/output interrupt, buffering, multitasking, 
spooling, runtime libraries, link-loading, and programs for sorting records in files. 

(3) The first microcomputers did not have the capacity or need for the elaborate 
operating systems that had been developed for mainframes and minis. 

(4) Microsoft Windows is a family of proprietary operating systems most commonly 
used on personal computers. 

(5) Ken Thompson wrote B, mainly based on BCPL, which he used to write UNIX, 
based on his experience in the multics project. 

【Ex2] 把 下 列 句 子 翻 详 成 中 文 . 

(1) 20 世纪 50 年 代 初 ,计算 机 一 次 只 能 执行 一 个 程序 。 

(2) Mac 系列 操作 系统 是 一 球 由 苹果 公司 开发 销售 ,包含 其 特有 知识 产权 的 图 形 界 
面 操作 系统 。 

(3) 20 世纪 60 年 代 ,IBM 的 OS/360 引入 一 个 涵盖 了 整个 产品 线 的 单一 操作 系统 概 
念 。 这 是 System/360 成 功 的 关键 。 

(4) 开发 成 功 的 微 操 作 系 统 往 往 从 ROM 加 载 并 在 监视 各 上 显示 。 

(5) 个 人 计算 机 使 用 的 最 新 版 本 操作 系统 是 Windows 7 ,而 服务 各 使 用 的 最 新 版 本 
操作 系统 则 是 Windows Server 2008 , 

(6) 类 UNIX 家 族 是 一 个 多 元 化 操作 系统 ,如 包括 System V BSD fll GNU /Linux 等 
几 个 主要 子 类 别 。 

(7)“ 类 UNIX”" 通 常 指 模拟 真正 UNIX 操作 系统 的 一 类 操作 系统 。 

(8) 符合 两 种 任务 要 求 的 典型 系统 是 MINIX, 而 有 些 系统 (如 Singularity ) 单纯 用 于 
研究 。 

【Ex3 ] 选择 适当 的 答案 填空 : 

(1)C (2) B (3) D (4) D (5) D 
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附录 G 参考 译文 
Unit 1 计算 机 结构 


Text A 计算 机 的 功能 


1. 中 央 处 理 单元 和 微 处 理 器 

一 台 通 用 计算 机 由 四 大 部 件 构成 : 算术 逻辑 单元 (ALU) .控制 单元 、 存储 需 , 以 及 输 
入 输出 (IO) 设 备 。 这 些 部 件 通常 由 一 组 线路 构成 的 总 线 连接 起 来 。 

每 个 部 件 都 由 数 以 万 亿 个 小 电路 组 成 ,这 些小 电路 可 以 被 一 个 电子 开关 装置 进行 开 
关 控 制 。 每 个 电路 代表 一 个 比特 的 信息 (二 进 制 数 字 ) ,使 得 电路 开启 时 代表 一 个 “1”, 关 
闭 时 代表 一 个 “0”( 正 逻辑 表示 )。 电 路 被 设置 成 逻辑 门 , 使 得 一 个 电路 的 一 个 或 多 个 状 
态 可 以 控制 其 他 电路 的 一 个 或 多 个 状态 。 

控制 单元 ,ALU .寄存 器 以 及 基本 的 IO( 及 其 紧密 耦合 的 其 他 硬件 ) 统 称 为 中 央 处 理 
单元 (CPU ) 。 早 期 的 CPU 由 许多 独立 的 元 件 构成 ,但 20 世纪 70 年 代 中 期 后 ,CPU 通常 
构建 在 一 个 集成 电路 上 VERAS iub Flan. 

1985 年 后 , 许多 处 理 需 设计 实现 了 MIPS( 2C H. BUR ELB Tat AK Ae po Ab FL at) Hs AR tn A 
的 某 个 版 本 , 并 得 到 广泛 使 用 。MIPS 是 指 由 MIPS 技术 (以 前 的 MIPS 计算 机 系统 ) 开 
发 的 精简 指令 集 计 算 机 (RISC ) 指令 集体 系 结构 (ISA) 。 早 期 的 MIPS 体系 结构 是 32 位 ， 
称 为 MIPS32 ， 随 后 增加 了 64 位 版 本 。MIPS32 指令 集 是 与 64 位 指令 的 MIPS64 指令 集 
同时 开发 的 。MIP32 标准 中 第 一 次 包含 协 处 理 吉 0 控制 指令 。 今天 ,MIP32 指令 集 是 最 
常见 的 MIPS 指令 集 , 与 大 多 数 CPU 兼容 。 由 于 其 相对 简单 ,MIP32 指令 集 也 是 大 学 课 
程 “ 计 算 机 结构 "中 最 常见 的 指令 集 内 容 。MIPS32 加 法 (ADD) 操 作 指 令 如 图 1-1 所 示 。 

控制 单元 (通常 称 为 控制 系统 或 中 央 控 制 带 ) 管理 计算 机 的 各 种 组 件 。 它 读 取 并 解 
释 ( 解码 ) 程 序 指令 ,将 它们 变 成 一 系列 激活 计算 机 其 他 部 分 的 控制 信号 。 先 进 的 计算 机 
控制 系统 可 能 会 改变 一 些 指 令 的 顺序 ,以 便 提高 性 能 。 

在 所 有 的 CPU 中 ,一 个 关键 部 件 是 程序 计数 器 , 它 是 一 个 特殊 存储 单元 (一 个 寄存 
ar) ,用 于 跟踪 下 一 条 指令 在 存储 器 中 读 取 的 位 置 。 

控制 系统 的 功能 如 下 ,注意 ,这 是 一 个 简化 的 描述 ,其 中 一 些 步骤 可 能 并 行 处 理 , 或 因 
不 同 的 CPU 类 型 以 不 同 的 顺序 执行 。 

根据 程序 计数 器 指示 的 单元 读 取 下 一 条 指令 的 代码 。 

将 数值 代码 指令 解码 成 其 他 系统 的 一 组 命令 或 信号 。 

程序 计数 器 加 1 ,使 其 指向 下 一 条 指令 。 

从 内 存单 元 (或 从 输入 设备 ) 读 取 指 令 所 需 的 任何 数据 。 所 需 数 据 的 位 置 通常 存储 
在 指令 代码 中 。 

提供 必要 的 数据 给 ALU 或 寄存 器 。 
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如 果 该 指令 需要 ALU 或 指定 的 人 硬件 完成 , 则 控制 硬件 执行 所 请 求 的 操作 。 

将 ALU 返回 的 结果 写 人 存储 需 位 置 或 寄存 器 ,或 一 个 输出 设备 。 

由 于 该 程序 计数 器 (从 概念 上 ) 仅 是 另 一 类 存储 器 单元 , 它 可 以 通过 在 ALU 进行 计 
算 而 改变 。 向 程序 计数 器 加 100 ,将 导致 读 取 下 一 条 指令 是 在 程序 指令 再 前 进 100 的 位 
置 。 修 改 程序 计数 器 的 指令 通常 被 称 为 “ 跳 转 ”, 允许 循环 ( 即 由 计算 机 重复 进行 ) 并 经 常 
与 条 件 指令 执行 (控制 流 的 两 个 例子 ) 。 

值得 注意 的 是 ,控制 单元 经 过 处 理 的 指令 序列 引起 的 系列 操作 本 和 号 就 像 一 个 短小 的 
计算 机 程序 。 事 实 上 ,在 一 些 更 复杂 的 CPU 设计 中 ,还 有 另 一 种 更 小 的 计算 机 称 为 微 程 
序 核 ,运行 微 码 程序 驱动 所 有 这 些 事件 发 生 。 

2. 算术 /逻辑 单元 (ALU) 

ALU 能 执行 两 类 操作 : 算术 运算 和 逻辑 运算 。 

特定 的 ALU 支持 的 算术 运算 集合 可 能 限定 为 加 法 和 减法 ,或 可 能 包括 乘法 或 除法 或 
三 角子 数 (如 正弦 余弦 等 ) 和 平方 根 。 有 些 仪 能 进行 整数 ( 整数) 运算 ,而 其 他 可 使 用 浮 
点 数 表示 实数 ,尽管 是 有 限 精度 。 然 而 , 仅 能 执行 最 简单 操作 的 任何 计算 机 都 可 以 通过 编 
FE ,将 很 复杂 的 操作 分 解 成 它 可 以 执行 的 简单 步 又。 因此 ,任何 计算 机 都 可 以 编程 执行 任 
何 算术 运算 ,尽管 这 样 做 将 花费 更 多 的 时 间 ,如 果 它 的 ALU 不 直接 支持 这 样 的 操作 。 一 
个 ALU 也 可 比较 数值 大 小 并 返回 布尔 真 值 (True 或 False) ,这 取决 于 是 等 于 .大 于 或 小 
于 其 他 数 (“64 是 否 大 于 65?”) 。 

逻辑 运算 包括 布尔 逻辑 : AND .OR .XOR 和 NOT。 可 以 创建 复杂 的 条 件 语 句 和 处 理 
布尔 逻辑 ,这些 都 有 用 。 

超标 量 计 算 机 可 以 包含 多 个 ALU ,使 它们 可 以 在 同一 时 间 处 理 多 条 指令 。 具 有 
SIMD 和 MIMD 特性 的 图 形 处 理 右 和 计算 机 和 常 党 提供 可 以 执行 拓 量 和 算 阵 算术 运算 
的 ALU, 

3. 内 存 

计算 机 数据 存储 通常 称 为 存储 或 内 存 , 是 由 计算 机 组 件 和 记录 介质 构成 的 一 种 技 
A, 用 于 保存 数字 数据 。 如 图 1-2 所 示 的 磁 芯 存储 器 是 一 种 随机 存 取 计算 机 内 存 , 主要 
在 1955 一 1975 年 这 20 年 使 用 。 

磁性 核心 存储 器 计算 机 内 存 占 据 整个 20 世纪 60 ER, 直到 它 被 半导体 存储 器 
取代 。 

可 以 把 计算 机 存储 器 当成 放置 或 读 取 数 字 的 单元 列表 。 每 个 单元 都 有 一 个 编号 称 为 
“地 址 ” ,并且 可 以 存储 一 个 数字 。 可 以 指令 计算 机 “把 数字 123 放 到 编号 为 1357 的 单 
元 ”或 “将 单元 1357 里 的 数 加 到 单元 2468 上 ,并 把 答案 写 进 单元 1595”。 存 储 在 内 存 中 
的 信息 可 能 代表 实际 的 任何 事情 。 将 字母 .数字 ,甚至 计算 机 指令 存 人 存储 需 同 等 容易 。 
由 于 CPU 并 不 区 分 不 同类 型 的 信息 内 容 , 所 以 依靠 软件 对 内 存 存 储 的 一 串 数字 给 出 其 意 
义 解释 。 

在 几乎 所 有 的 现代 计算 机 ,每 个 存储 需 单 元 都 设置 成 存储 8 比特 组 成 ( 称 为 字 节 ) 的 
二 进 制 数字 。 每 个 字 节 能 够 代表 256 个 不 同 的 数字 (2”= 256 ) ;无 论 是 0 ~ 255 或 者 
-128 ~ +127。 存 储 更 大 的 数字 ,可 以 使 用 几 个 连续 的 字 节 (通常 使 用 两 个 .4 个 或 8 个 
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字 节 ) 。 当 需要 负数 时 ,它们 通常 存储 成 2 的 补 码 表示 法 。 其 他 安排 也 是 可 能 的 ,但 通常 
看 不 到 ,除了 专门 的 应 用 或 历史 的 上 下 文 。 只 要 能 用 数字 表示 ,计算 机 在 存储 器 中 就 可 以 
存储 任何 类 型 的 信息 。 现 代 计 算 机 拥有 数 十 亿 , 其 至 万 亿 内 存 字 节 。 

CPU 包含 称 为 寄存 絮 的 一 组 特殊 存储 右 单 元 , 比 主 存储 读 取 和 写 人 更 迅速 。 取 决 于 
CPU 的 类 型 ,CPU 中 通常 有 2 ~ 100 个 寄存 帮 。 寄 存 副 用 于 存储 最 经 党 需要 访问 的 数据 
项 ,以 避免 每 次 需要 数据 ,都 访问 主 存储 项。 因数 据 在 不 断 工作 ,所 以 减少 了 要 访问 主 存 
储 需 的 需求 (相对 于 ALU 和 控制 单元 ,这 往往 是 缓慢 的 操作 ) , 极 大 地 提高 了 计算 机 的 
速度 。 

计算 机 内 存 主要 有 两 种 类 型 : 随机 存 取 存储 需 ( 或 称 RAM) All BEIT Mi ait (9X PR 
ROM). RAM 按照 CPU 的 指令 随时 可 读 取 和 写 入 ,但 ROM 是 预先 装 人 数据 和 软件 , 永 
远 不 会 改变 ,所 以 CPU 只 能 从 中 读 出 。ROM 经 典范 例 用 来 存储 计算 机 的 初始 化 启动 指 
令 。 一 般 情况 下 , 当 计 算 机 电源 关闭 时 ,RAM 的 内 容 被 删除 ,但 ROM 永远 保留 其 数据 。 
在 PC 中 ,ROM 包含 一 个 专门 的 程序 , 称 为 BIOS ,只 要 计算 机 开机 或 重新 启动 ,计算 机 操 
作 系 统 程序 就 将 其 从 硬盘 驱动 器 加 载 到 RAM。 在 艇 人 式 计 算 机 中 ,经 常 没 有 磁盘 驱动 
fe ,所 需 的 所 有 软件 可 以 存储 在 ROM 中 。 存 储 在 ROM 中 的 软件 通常 被 称 为 固件 ,因为 
它 从 名 称 上 比 软件 更 像 硬 件 。 闪 速 存 储 器 模糊 了 ROM 和 RAM 之 间 的 区 别 ,因为 关闭 时 
其 数据 可 以 保留 ,也 可 以 重 写 。 通 常 , 它 比 常规 的 ROM 和 RAM 慢 得 多 ,因此 , 它 的 使 用 
受到 限制 ,只 适用 于 不 需 高 速 访问 的 场合 。 

在 更 复杂 的 计算 机 中 可 以 有 一 个 或 更 多 的 RAM 高 速 缓冲 存储 需 , 它 们 的 速度 比 寄 
存 器 慢 , 但 比 主 存储 器 快 。 有 这 种 高 速 缓存 的 计算 机 一 般 设 计 成 将 经 常 使 用 的 数据 自动 
移动 到 缓存, 往往 不 需要 程序 员 任 何 干预 。 

4. 输入 输出 (1/0) 

LO 是 计算 机 用 来 与 外 界 交换 信息 的 通道 。 提 供给 计算 机 的 输入 或 输出 设备 称 为 外 
设 。 在 一 个 典型 的 个 人 计算 机 中 ,外 设 包括 输入 装置 (如 键盘 和 鼠标 ) ,以 及 输出 设备 (如 
显示 需 和 打印 机 ) 。 硬 盘 驱 动 吉 、 软 盘 驱 动 器 和 光盘 驱动 需 都 被 当 作 输入 设备 。 计 算 机 
网 络 是 L/O 的 另 一 种 形式 。 

通常 ,I/O 设备 是 复杂 的 计算 机 系统 ,拥有 它们 自己 专用 的 CPU MAMo BIJE Ab 
理 单元 可 能 包含 50 个 或 更 多 个 微小 的 计算 机 计算 需要 显示 的 三 维 图 形 。 现 代 台 式 计算 
机 含有 许多 小 型 计算 机 ,可 以 帮助 主 CPU 执行 1/0, 

5. 多 任务 

虽然 计算 机 可 看 成 运行 存储 在 主 存 储 器 中 的 一 个 巨大 程序 ,但 在 一 些 系 统 中 ,必须 同 
时 运行 多 个 程序 并 显示 出 来 。 这 通过 多 任务 处 理 实 现 , 即 让 计算 机 在 每 个 程序 之 间 依 次 
快速 切换 运行 。 

这 样 做 的 一 种 方法 是 ,用 一 个 称 为 中 断 的 特殊 信号 , 它 可 以 周期 性 地 导致 计算 机 停止 
执行 它 在 那里 的 指令 ,而 做 其 他 事情 。 只 要 记 住 它 被 中 断 之 前 的 执行 位 置 , 计 算 机 就 可 以 
稍 后 再 返回 到 该 任务 。 如 果 几 个 程序 “同时 ?运行 ,中 断 发 生 需 可 能 会 导致 每 秒 几 百 次 中 
断 , 每 次 都 使 程序 进行 切换 。 因 为 现代 计算 机 执行 指令 的 速度 比 人 类 的 感觉 快 几 个 数量 
级 , 它 可 能 显现 出 许多 程序 同时 运行 的 现象 ,即使 在 任何 给 定 的 瞬间 永远 只 有 一 个 程序 被 
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执行 。 多 任务 的 这 种 方法 有 时 称 为 “时 间 共 至 ” ,因为 每 个 程序 依次 分 配 到 一 个 时 间 


in 
在 廉价 计算 机 时 代 来 临 之 前 ,进行 多 任务 处 理 的 主要 用 途 是 让 许多 人 共享 同一 台 计 
算 机 。 


看 似 多 任务 让 几 个 程序 之 间 切 换 运行 ,会 导致 计算 机 运行 更 慢 , 正 比 于 运行 程序 的 数 
量 。 然 而 ,大 多 数 程序 花费 大 量 的 时 间 等 待 缓慢 的 输入 输出 设备 完成 它们 的 任务 。 如 果 
程序 正在 等 待 用 户 点 击 鼠 标 或 按 下 键盘 上 的 一 个 键 ,那么 它 不 会 花费 “时 间 切 片 ”, 直 到 
它 等 待 的 事件 发 生 。 这 将 释放 给 其 他 程序 使 用 ,这 样 ,很 多 程序 可 能 在 同一 时 间 运 行 ,而 
没有 不 可 接受 的 速度 损失 发 生 。 

6. 多 进程 

有 些 计算 机 在 多 处 理 配置 环境 设计 成 分 发 它们 的 任务 横路 多 个 CPU ,这 一 技术 曾经 
只 在 大 型 .功能 强大 的 机 需 , 如 超级 计算 机 .大 型 计算 机 和 服务 器 中 使 用 。 多 处 理 器 和 多 
核心 (在 单个 集成 电路 上 的 多 个 CPU) 个 人 计算 机 和 膝 上 型 计算 机 现在 已 广泛 使 用 ,并 且 
在 低 端 市 场 也 正 越 来 越 多 地 开花 结果 。 

尤其 是 超级 计算 机 , 它 常 常 具 有 高 度 不 同 的 独特 结构 ,区 别 于 基本 存储 程序 结构 和 通 
用 计算 机 。 它 们 往往 拥有 成 千 上 万 的 CPU ,特制 的 高 速 互 连 和 专门 的 计算 硬件 。 这 种 设 
计 往 往 只 对 特定 任务 有 用 ,同时 需要 大 型 程序 组 织 才 能 成 功 地 、 最 大 限度 地 利用 可 用 资 
源 。 超 级 计算 机 通常 应 用 于 大 型 仿真 .图形 泻 染 和 加 密 应 用 ,以 及 其 他 所 谓 的 “让 人 为 难 
的 并 行 " 任 务 。 

7. 联网 和 互联 网 

20 世纪 50 年 代 开 始 ,计算 机 已 被 用 于 协同 共享 多 个 位 置 之 间 的 信息 。 美 国 军 方 的 
SAGE 系统 就 是 一 个 大 型 范例 ,这 导致 出 现 一 些 特 殊 用 途 的 商业 系统 ,如 Sabre, 

20 世纪 70 年 代 , 美 国 各 地 研究 机 构 的 计算 机 工程 师 开 始 使 用 电信 技术 将 自己 的 计 
算 机 连接 起 来 。 这 项 工作 由 ARPA (现在 的 DARPA) 资 助 ,而 且 由 它 产生 的 计算 机 网 络 
被 称 为 ARPANET。 技 术 发 展 使 得 ARPANET 可 以 不 断 扩 散 和 演变 。 

随 着 时 间 的 推移 ,网 络 传播 超越 学 术 和 军事 机 构 , 并 成 为 著名 的 互联 网 。 联 网 的 出 现 
使 得 所 涉及 计算 机 的 性 质 和 边界 需要 重新 定义 。 计 算 机 操作 系统 和 应 用 程序 概念 进行 了 
修改 ,使 其 能 力 定 义 包 括 访问 网 络 上 其 他 计算 机 的 资源 ,如 外 设 存储 的 信息 和 类 似 物 , 作 
为 个 人 计算 机 资源 的 扩展 。 最 初 , 这 些 设施 主要 供 高 科技 环境 中 的 工作 人 员 使 用 ,但 20 
世纪 90 年 代 后 , 像 电 子 邮 件 和 万 维 网 普及 应 用 ,与 低 价 、 快 速 的 网 络 技术 (如 以 太 网 和 
ADSL) 发 展 相 结合 ,计算 机 联网 变 得 随处 可 见 。 事 实 上 ,通过 网 络 连接 的 计算 机 数量 惊 
人 增长 。 个 人 计算 机 定期 连接 到 Internet 进行 通信 和 接收 信息 , 占 非 常 大 的 比例 。 “无 
线 " 网 络 经 常 使 用 移动 电话 网 络 ,意味 着 网 络 即使 在 移动 计算 环境 中 ,也 正在 日 益 普 及 。 


Text B 计算 机 技术 的 未 来 


有 段 时 间 , 人 们 一 直 硕 望 能 不 断 得 到 最 快 的 计算 机 ,对 不 对 ? 

当 386 出 现 后 ,大 家 都 认为 它 酷 酷 的 .速度 快 ,每 人 都 需要 一 人 台 。 

突然 ,应 用 程序 用 掉 了 它 的 能 力 ,386 变 得 缓慢 ,接着 486 就 出 现 了 ,每 人 都 需要 
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目前 的 趋势 是 ,我们 充分 挖掘 硬件 性 能 ,成 为 可 用 ,然后 想 要 更 多 。 有 点 像 * 永 不 满 
足 的 钱 ( ARAL MESEL) ”的 说 法 。 

但 期 望 这 一 趋势 将 继续 下 去 是 存在 问题 的 。 

事实 上 ,普通 人 需要 一 台 计 算 机 做 的 事 就 这 么 多 。 基 本 上 ,计算 机 作为 一 个 “设备 ”， 
能 够 与 我 们 的 感官 进行 有 限 的 相互 作用 。 这 意味 着 ,直到 我 们 看 到 嗅觉 鼠标 前 ,我 们 基本 
上 需要 

全 速 视频 输出 : 电影 解码 /演示 /产生 ,游戏 。 

全 速 视频 输入 : 视觉 识别 ,电影 保存 /编码 /压缩 。 

全 速 音频 输出 : 声音 解码 /混合 ,语音 合成 。 

全 速 音频 输入 : 语音 识别 ,录音 /压缩 。 

这 一 说 法 适用 于 “普通 人 ” ,不 是 像 你 和 我 这 样 的 计算 机 极 客 , 想 要 运行 庞大 的 仿真 
程序 或 做 软件 开发 或 CAD 设计 ,仍然 需要 有 一 个 全 副 功 能 的 家 用 工作 站 。 我 们 这 类 人 
占 少 数 。 

大 多 数 ( 上 面 提 的 ) 要 求 , 今 天 的 计算 机 已 经 可 以 满足 了 。 其 中 许多 也 都 可 用 ,只 是 


还 没有 达到 全 速 ( 如 全 屏 视 频 生 成 “无 瑕 "语音 识别 ) ,并 且 近 几 年 内 购买 的 现 有 的 计算 
设备 都 可 以 满足 。 


你 有 没有 注意 到 ,人 们 不 再 过 多 地 谈论 处 理 需 的 速度 是 多 少 。 如 果 你 到 本 地 计算 机 
商店 ,他 们 谈论 的 多 是 RAM ,硬盘 .屏幕 大 小 .电池 和 其 他 功能 。 几 年 前 ,他 们 谈 的 都 是 处 
理 磺 速度 ,而 现在 它 变 得 越 来 越 不 重要 ,不 久 也 许 会 成 为 一 个 脚注 ,作为 一 台 计 算 机 的 规 
格 条 件 。 

那么 , 接 下 来 会 发 生 什 么 ? 

东西 会 变 得 更 小 更 快 。 

过 去 ,笔记 本 电脑 笨重 速度 缓慢 日 能 力 微 弱 。 它 不 能 完成 一 台 家 用 计算 机 的 所 有 任 
务 。 这 将 不 再 发 生 ,我 的 2 磅 超 轻 注 笔 记 本 电脑 (我 仅 花 150 美元 ;顺便 说 一 句 ) 基本 上 
能 与 最 先进 的 家 用 工作 站 媲美 。 可 以 看 到 ,目前 已 涌现 出 功能 越 来 越 强 大 的 小 型 计算 机 。 
像 Palm( 手持 计算 辅助 设备 ) 这 样 的 设备 ,只 是 商业 的 临时 新 方向 。Palm 仅 有 真实 操作 
系统 的 部 分 功能 , 也 仅 有 真正 计算 机 的 子 集 功 能 。 很 快 你 就 能 得 到 一 台 和 Palm 大 小 相 
同 的 全 功能 计算 机 ,而 且 价 格 也 差不多 。 你 宁愿 有 一 个 内 置 微型 浏览 右 的 个 人 信息 管理 
器 , 还 是 宁愿 有 装 有 你 刚 下 载 最 新 的 Netscape/Mozilla/Opera 浏览 器 内 含有 最 新 版 
Flash/Java/Shockwave 功能 的 个 人 信息 管理 需 ? 还 是 这 样 的 个 人 信息 管理 需 , 具 有 提供 
地 址 列表 的 应 用 程序 功能 , 或 可 以 运行 你 想 要 的 任何 地 址 列表 的 应 用 程序 功能 ,并 有 玩 
Doom( 毁灭 战士 ) 游 戏 的 功能 ? 

这 个 论点 也 适用 于 数据 存储 。 

每 个 人 都 想 要 他 们 能 得 到 的 最 大 硬盘 。 我 们 不 断想 出 更 多 的 方法 满足 他 们 的 需求 
(MP3 .视频 等 ) ,而 我 们 需要 不 断 更 新 升级 。 尽 管 现 在 ,你 的 硬盘 上 的 存储 空间 不 足 是 一 
个 非常 罕见 发 生 的 事情 。 我 曾经 不 得 不 压缩 文件 并 将 文件 保存 到 软盘 上 ,才能 处 理 一 些 
事情 。 
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现在 这 些 日 子 我 连任 何 磁盘 都 没有 。 在 我 的 计算 机 上 ,我 通常 只 写 和 人 CD ,以 此 作为 
信息 的 备份 方法 。 

在 未 来 不 到 10 年 的 时 间 内 ,你 能 够 将 完整 的 视频 存储 在 硬盘 上 ,就 像 你 今天 可 以 在 
那里 存储 音频 一 样 。 你 会 有 一 个 1000 部 的 电影 播放 列表 ,就 像 你 今天 的 MP3 播放 器。 

几 年 后 ,你 就 可 以 把 它 放 在 你 的 钥 是 串 上 。 之 后 ,你 真 的 需要 买 一 个 更 大 的 便 盘 吗 ? 
在 某 些 时 候 , 你 将 能 够 存储 更 多 的 视频 和 音频 ,你 将 能 够 体验 你 的 一 生 。 这 时 ,你 就 不 需 
要 关注 下 一 个 驱动 器 大 小 了 ,好 吗 ? 

我 承认 我 的 笔记 本 电脑 和 家 里 的 计算 机 有 很 大 的 区 别 。 主 要 是 键盘 .21 英寸 的 显示 
ar Al CD-RW( 可 读 写 光驱 ) (虽然 现在 大 多 数 笔 记 本 电脑 都 有 DVD/CD/RW 等 ) 。 

现在 让 我 们 来 看 看 未 来 。 

但 这 样 做 之 前 ,要 考虑 过 去 ,回想 计算 机 行业 曾 发 生 了 什么 。 

最 初 , 钱 主要 花 在 大 型 机 上 。 个 人 计算 机 作为 一 种 奢侈 的 嗜好 而 存在 ,但 钱 在 大 型 机 
行业 里 流动 。 这 一 切 都 与 PC 和 大 型 机 相 比 有 多 大 作用 有 关 。 随 着 性 能 的 提高 ,服务 器 
开始 做 很 多 大 型 机 可 以 做 的 事情 ,而 钱 仍 花 在 大 型 机 市 场 上 。 真 正 的 问题 是 ,有 足够 程度 
的 计算 能 力 (每 美元 ) 实际 上 是 至 关 重 要 的 。 低 于 这 个 程度 ,都 会 显得 太 慢 ,你 会 想 要 更 
快 的 速度 。 高 于 这 个 能 力 , 在 技术 和 发 展 市 场 上 只 会 有 用 。 然 后 是 工作 站 ,它们 开始 达 
到 计算 的 能 力 , 并 开始 替代 服务 需 。 然 后 是 个 人 计算 机 (PC) 。 个 人 计算 机 市 场 腾 飞 ,个 
人 计算 机 开始 蔡 换 工 作 站 。 这 个 水 印 特效 在 电影 业 中 得 到 了 最 好 的 宣传 ,当时 像 人 泰坦 
尼克 号 》 这 样 的 电影 被 广 为 宣 传 ,是 通过 使 用 大 量 便宜 的 PC , 而 不 是 工作 站 制作 出 来 的 。 
现在 我 们 正在 转 回 笔记 本 电脑 ,更 小 笔记 本 将 是 下 一 个 ,然后 是 手持 设备 。 目 己 完 成 这 一 
推理 。 

这 是 我 对 未 来 的 预测 。 

你 会 有 一 个 计算 设备 。 它 将 是 一 个 处 理 需 ,是 xxx MHz ,其 中 ' xxx “足够 快 ” 。 它 
也 将 有 固态 存储 器 ,有 xxx GB ,其 中 ' xxx “足够 大 ”。 这 个 小 家 伙 将 类 似 手 机 大 小 或 更 
小 ,成 本 与 手机 大 致 相当 。 

你 回 家 会 把 它 挂 接 在 显示 顺和 键盘 上 的 一 个 端口 上 。 而 在 路 上 ,你 会 把 它 放 在 一 个 
wA Palm 大 小 触摸 显示 屏 的 外 碗 上 ,让 你 访问 它 的 所 有 信息 ,甚至 听 音 乐 或 看 视频 。 然 
后 你 可 能 会 将 它 连 上 你 的 相机 外 壳 ( 或 者 你 的 管理 者 外 帝 上 可 能 有 镜头 ……) ,你 想 拍 多 
少 张 照片 就 拍 多 少 张 ,因为 你 的 存储 空间 可 以 容纳 1000 部 电影 ,所 以 你 永远 无 法 用 静止 
照片 和 家 庭 视 频 填 满 它 ,也 不 需 与 家 用 设备 同步 。 你 甚至 可 以 拥有 完全 的 无 线 功 能 ,你 的 
照片 可 以 自动 传 到 你 的 网 络 相 册 。 当 你 旅行 回 家 的 时 候 , 你 可 以 把 这 个 设备 放 到 你 的 影 
院 系 统 里 ,你 可 以 看 电影 或 从 你 的 旅行 镜头 中 开始 观看 。 你 可 以 在 你 的 设备 上 加 密 某 种 
形式 的 净 贷 币 ,这 样 , 你 也 可 以 用 它 购 买 东 西 。 当 你 开车 的 时 候 , 可 以 把 它 放 在 车 里 , 听 你 
自己 的 每 一 首 歌 。 你 可 以 在 目 己 的 车 上 安装 一 个 GPS , 它 可 以 使 用 地 图 查询 等 服务 为 你 
指 路 。 大 你 的 爱人 给 你 发 电子 邮件 ,你 会 用 耳机 外 设 和 电话 软件 给 她 回电 话 。 

但 重要 的 一 点 是 ,你 不 需要 得 到 多 个 计算 设备 ,也 不 需要 再 拥有 家 庭 计算 机 。 你 会 
一 个 计算 设备 , 它 会 像 钱 包 一 样 伴随 你 ,因为 它 将 取代 你 的 信用 卡 、 你 的 手机 、 你 的 传真 
机 、 你 的 DVD 播放 机 你 的 立体 声 .你 的 浏览 器 .你 的 助理 需 、 你 的 电子 邮件 等 。 
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然后 会 有 一 些 博物 馆 , 所 有 这 些 东西 都 摆 放 在 那里 ,人 们 可 以 观看 和 感受 ,就 像 今天 
我 们 嘲笑 ENIAC 和 真空 管 一 样 。 


Unit2 编程 语言 
Tex A CHEAM 


几乎 所 有 的 编程 语言 都 具有 与 图 数 等 价 的 功能 。 你 可 能 已 经 遇 到 过 称 为 子 程序 或 过 
程 的 别名 。 

有 些 语 言 通过 是 否 有 返回 值 区 分 函数 。C 语言 假定 每 个 函数 都 会 返回 一 个 值 。 磊 程 
序 员 想 返回 值 ,通常 使 用 return 语句 实现 。 如 果 不 需 要 返回 值 ,调用 函数 时 就 不 要 使 用 。 

这 里 是 一 个 求 双 精 度数 的 非 负 整 数 次 贤 的 函数 ,返回 计算 的 结果 。 

double power (double val, unsigned pow) 

{ double ret val = 1.0; 

unsigned i; 


for(i = 0; i < pow; i++) 
ret val * = val; 


retum(ret val); 
} 


该 困 数 由 一 个 简单 的 算法 , 自 乘 自身 pow K, for 循环 用 来 控制 乘法 的 次 数 ,变量 
ret val 用 来 存储 返回 值 。 小 心 仔细 地 编程 已 保证 了 边界 条 件 是 正确 的 。 

让 我 们 看 看 这 个 函数 的 详细 信息 : 

double power (double val, unsigned pow) 

OAT AE PRE LFR, ERR TI Ie (EL SY eR, JS rf HH KR 
数列 表 。 这 些 参 数 及 其 类 型 都 用 括号 括 起 来 ,用 逗号 分 隔 。 

国 数 的 主体 是 由 一 组 花 括 号 构成 的 范围 。 这 里 声明 的 变量 将 被 视 为 局 部 的 ,除非 特 
别 声明 为 static 或 extern 类 型 。 

retum(ret val); 

到 达 return 语句 , FE FF B di m BG Inl 56:358] A eR, d LES ELA ERICH) a eE, A 
果 在 任何 返回 值 之 前 到 达 最 终 的 花 括号 ,那么 图 数 将 自动 返回 ,返回 值 将 是 毫 无 意义 的 。 

这 个 函数 例子 可 以 在 其 他 哺 数 中 调用 ,看 起 来 像 如 下 这 样 . 

result = power (val, pow); 

这 是 调用 乘 需 图 数 并 将 结果 赋 给 变量 result, 

下 面 是 一 个 没有 返回 值 的 函数 例子 。 

void error line(int lire) 
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( fprintf (stderr, "Error in input data: line d\n", line); 

} 

该 定义 使 用 可 选 的 类 型 void。 这 表明 没有 用 到 返回 值 ,否则 该 限 数 与 前 面 的 例子 大 
人 臻 相同 ,不 同 之 处 在 于 该 浮 数 没有 返回 语句 。 有 些 void 类 型 的 限 数 可 以 使 用 return ,而 只 
是 强制 从 限 数 中 提前 退出 ,并 且 不 返回 任何 值 。 这 有 点 像 使 用 break 跳出 循环 。 

这 个 例子 还 显示 了 尹 数 的 新 特性 。 


fprintf (stderr, "Error in input data: line $ d\n", line); 


这 是 关于 printf 语句 的 变 体 ; fprintf 将 其 输出 发 送 到 文件 中 。 在 这 种 情况 下 ,该 文件 
是 stderr, stderr 是 一 个 特殊 的 UNIX 文件 ,其 用 作 和 错误 消 朋 的 信道 。 它 通常 连接 到 计算 
机 系统 的 控制 台 上 ,所 以 这 是 从 你 的 程序 显示 错误 信息 的 好 方法 。 即 使 程序 的 正 背 输出 
已 被 重 定向 到 文件 或 打印 机 上 ,发 送 到 stderr 的 消息 也 会 出 现在 屏 莫 上 。 

该 图 数 的 调用 方式 如 下 。 


error line(line number); 


Tex B J2ME 有 关 资 料 


1. J2ME 的 组 织 结构 如 何 

传统 的 计算 设备 使 用 相当 标准 的 硬件 配置 ,如 显示 需 、 键 盘 .鼠标 以 及 大 容量 的 内 存 
和 永久 存储 设备 。 

然而 ,新 一 代 计 算 设 备 缺 乏 便 件 配置 的 继 素 性 。 一 些 设 备 不 带 显 示 需 、 永久 存储 需 、 
键盘 或 鼠标 ,并 且 内 存在 各 小 型 计算 设备 相互 不 兼容 。 

小 型 计算 设备 之 间 缺 乏 统 一 的 便 件 配置 ,成 为 Java 社区 进程 项 目 JCPP ( Java 
Community Process Program) 面临 的 一 个 巨大 的 挑战 ,该 项 目 负 责 为 小 型 计算 设备 的 JVM 
和 J2ME 制定 标准 。 

J2ME 必须 服务 于 许多 不 同 种 类 的 小 型 计算 设备 ,包括 视频 电话 有 线 电 视 数 字 机 顶 
íx 蜂 宽 电话 和 个 人 数字 助理 机 。JCPP 的 挑战 是 开发 出 在 具有 非 标 准 的 硬件 配置 小 型 计 
算 设 备 中 可 以 实现 的 Java 标准 。 

JCPP 已 经 采用 了 双 面 的 办 法 解决 (满足 ) 小 型 计算 设备 的 需要 。 首 先 , 他 们 定义 了 
每 个 设备 上 运行 的 Java 运行 环境 和 核心 类 ,这 称 为 配置 。 配 置 定义 了 特定 小 型 计算 设备 
的 Java 虚拟 机 。 有 两 种 配置 : 一 种 用 于 手持 式 的 设备 ; 男 一 个 用 于 插入 式 设 备 。 接 下 来 ， 
JCPP 定义 小 型 计算 设备 类 别 的 概要 文件 。 概 要 文件 包含 的 类 使 开发 人 员 能 够 实现 对 小 
型 计算 设备 相关 的 功能 。 

2. J2ME 配置 

截止 到 现在 , J2ME 有 两 种 配置 有 限 连接 设备 配置 (CLDC) 和 连接 设备 配置 
(CDC) 。CLDC 是 为 有 限 内 存 容量 的 16 位 或 32 位 小 型 计算 设备 设计 的 。 

CLDC 设备 通常 有 160 ~512KB 可 用 内 存 并 由 电池 供电 。 它 们 还 使 用 一 种 不 兼容 、 
军人 带宽 的 无 线 网 络 连接 ,并 且 可 以 没有 用 户 界面 。CLDC 设备 使 用 的 K-Java 虚拟 机 
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(KVM) 环境 是 一 个 JVM. CLDC 精简 版 本 ,适用 装置 包括 寻呼机 、 个 人 数字 助理 机 | 1E 95 
电话 .专用 的 终端 和 带 有 128 ~512KB 内 存 的 手持 电子 设备 。CDC 设备 使 用 32 位 架构 ， 
至 少 支持 两 兆 的 内 存 和 完整 功能 的 JVM, CDC 设备 包括 数字 机 顶 盒 家电、 导航 系统 、 销 
售 点 终端 和 智能 手机 。 

3. JAME 概要 文件 

概要 文件 (profile ) 包 含 Java 类 ,便于 一 个 特定 的 小 型 计算 设备 或 一 类 小 型 计算 设备 
实现 所 需要 的 功能 。 由 于 小 型 计算 技术 的 不 断 发 展 , 基 于 此 , J2ME 不 断定 义 出 新 的 概要 
文件 。 截 至 目前 ,已 定义 了 7 类 概要 文件 , 即 基础 概要 文件 游戏 概要 文件 移动 信息 设备 
概要 文件 .PDA 概要 文件 .个 人 概要 文件 个 人 基础 概要 文件 以 及 RMI 概要 文件 。 

e 基础 概要 文件 用 来 参与 CDC 配置 ,是 其 他 类 概要 文件 的 核心 ,几乎 参与 所 有 CDC 
配置 ,因为 其 包含 核心 的 Java 类 。 

e 游戏 概要 文件 也 用 于 CDC 配置 ,包含 任何 小 型 计算 设备 开发 的 游戏 应 用 程序 所 
需 的 类 。 

e 移动 信息 设备 概要 文件 (MIDP) 用 来 参与 CLDC 配置 ,包含 提供 本 地 存储 的 类 .用 
户 界 面 和 移动 计算 设备 如 运行 Palm 操作 系统 设备 的 应 用 程序 所 需 的 网 络 功 能 。 
MIDP 用 了 无 线 的 Java 应 用 程序 。 

e PDA 概要 文件 (PDAP) 用 来 参与 CLDC 配置 ,并 包括 利用 复杂 资源 的 类 (如 个 人 
数字 助理 机 的 类 ) 。 这 些 功 能 包括 更 好 的 显示 ,以 及 更 多 的 内 存 , 这 是 与 MIDP 移 
动 设 备 ( 如 蜂 需 手机 ) 所 使 用 的 资源 相 比 。 

e 个 人 概要 文件 用 来 参与 CDC 配置 ,需要 基础 概要 文件 ,还 包括 用 来 实现 一 个 复杂 
用 户 界面 的 类 。 基 础 概要 文件 提供 核心 类 ,以 及 个 人 概要 文件 提供 实现 复杂 的 用 
户 界面 的 类 ,这 是 一 个 同时 能 显示 多 个 窗口 的 用 户 界面 。 

e 个 人 基础 概要 文件 类 似 于 个 人 概要 文件 , 它 用 来 参与 CDC 配置 ,需要 基础 概要 文 
件 。 然 而 ,个 人 基础 概要 文件 提供 实现 一 个 简单 的 用 户 界面 的 类 ,这 是 一 个 用 户 
界面 ,能 够 同时 显示 一 个 窗口 。 

。 将 RMI 概要 文件 用 来 参与 CDC 配置 ,需要 基础 概要 文件 ,其 中 包含 提供 远程 方 

法 调用 类 的 基础 核心 类 。 

小 型 计算 设备 存在 许多 不 断定 义 的 概要 文件 。JCPP 项 目 (java. sun. com/aboutjava/ 
communityprocess ) 的 产业 群 定 义 了 这 些 概 要 文件 。 每 个 小 组 确定 使 用 由 该 行业 生产 的 小 
型 计算 设备 的 标准 概要 文件 。 一 个 CDC 概要 文件 针对 的 是 一 类 小 型 计算 设备 ,在 基础 概 
要 文件 的 基础 上 由 核心 Java 类 扩展 而 成 。 这 些 设备 特定 类 包含 在 一 个 新 的 概要 文件 中 ， 
使 开发 人 员 能 够 创建 工业 级 应 用 。 但 是 ,这 些 基础 概要 文件 仅 针 对 CDC , 而 不 是 在 基础 
概要 文件 的 核心 类 上 针对 所 有 的 概要 文件 都 进行 扩充 。 

记 住 ,应 用 程序 仅 在 JVM 必要 的 类 或 开发 者 使 用 的 概要 文件 中 能 够 访问 小 型 计算 设 
备 的 软件 和 硬件 。 
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Unit3 离散 数学 
Text A 有 关 离 散 数学 


(1) 离散 数学 简介 

离散 数学 为 几 个 数学 分 支 的 统称 ,这 是 基于 离散 的 ,而 不 是 连续 的 数学 结构 的 研究 角 
度 的 总 称 。 相 比 实数 的 “平滑 ”的 特性 ,离散 数学 的 研究 对 象 如 整数 .图形 和 逻辑 命题 ,不 
以 平滑 方式 变化 ,而 有 明显 的 离散 值 ,因此 离散 数学 不 研究 “连续 数学 ”的 课题 ,如 微 积分 
和 分 析 。 离 散 对 象 通 篆 可 以 通过 整数 枚 举 。 更 准确 地 说 ,离散 数学 是 处 理 可 数 集 的 数学 
(与 整数 的 子 集 具 有 相同 基数 的 集合 ,包括 有 理 数 ,但 不 是 实数 集 ) 的 分 支 。 然 而 “离散 
数学 ”这 个 词 还 没有 精确 并 为 大 家 接受 的 定义 。 事 实 上 ,离散 数学 很 少 描述 研究 哪些 内 
容 ,而 更 多 描述 不 研究 哪些 内 容 , 如 连续 变化 的 数量 及 其 相关 的 概念 。 

20 世纪 下 半 叶 ,由 于 数字 计算 机 的 发 展 需要 研究 不 连续 的 操作 步骤 和 存储 的 数据 离 
散 化 ,因此 离散 数学 得 到 深入 的 研究 。 离 散 数 学 的 概念 和 符号 应 用 于 人 研究 和 描写 计算 机 
科学 的 对 象 和 问题 ,如 计算 机 算法 编程 语言 .密码 学 、 自 动 定理 证 明和 软件 开发 。 结 果 ， 
计算 机 成 果 非 常 显著 。 

(2) 离散 数学 的 课题 

计算 机 科学 理论 包括 离散 数学 与 计算 相关 的 领域 。 它 大 量 借鉴 了 图 论 和 逻辑 学 , 包 
括 计算 机 科学 理论 中 的 计算 数学 算法 的 研究 成 果 。 可 计算 性 研究 什么 原则 下 可 以 进行 计 
算 , 并 与 逻辑 密切 相关 ,而 复杂 性 研究 所 需要 的 计算 时 间 。 自 动机 理论 和 形式 语言 理论 与 
可 计算 性 密切 相关 。 计 算 几何 算法 应 用 于 几何 的 问题 ,而 计算 机 图 像 分 析 应 用 于 图 像 的 
表示 。 计 算 机 科学 理论 也 包括 各 种 连续 计算 专题 研究 。 

逻辑 学 是 对 有 效 推 理 和 论证 原理 的 研究 ,也 是 对 一 致 性 健全 性 和 完整 性 的 研究 。 例 
如 ,在 大 多 数 逻 辑 系 统 (但 不 是 在 直觉 逻辑 ) 中 ,皮尔 斯 定律 ((p 一 q 一 p) 一 p) 是 一 个 定 
理 。 对 于 经 典 逻 辑 , 它 可 以 很 容易 地 用 真 值 表 进 行 验证 。 数 学 证 明 的 研究 在 逻辑 中 占有 
特殊 的 地 位 ,已 经 应 用 于 软件 的 自动 定理 证 明和 形式 化 验证 。 

逻辑 公式 是 离散 结构 ,就 像 证 明 一 样 ,它们 形成 有 限 的 树 ,或 者 更 广泛 地 说 ,是 形式 有 
向 无 环 图 形 结构 (每 个 推理 步骤 结合 一 个 或 多 个 前 提 分 支 而 给 出 一 个 单一 的 结论 ) 3E 
辑 公 式 的 真 值 通常 形成 一 个 有 限 集 , 它 一 般 限 于 两 个 值 : 真 值 和 假 值 ,但 逻辑 也 可 以 是 连 
续 值 ,如 模糊 逻辑 。 也 研究 无 限 证 明 树 或 无 限 派生 树 等 概念 ,如 无 限 逻 辑 。 

合 论 是 研究 集合 的 数学 分 支 ,它们 是 对 象 的 集合 ,如 | 蓝 色 ,白色 红色 | 或 所 有 素 
数 的 (无 限 ) 集 。 偏 序 集 和 关系 集 在 多 个 区 域 具有 应 用 。 

在 离散 数学 中 ,可 数 集 (包括 有 限 集 ) 是 主要 关注 点 。 集 合 论 作为 数学 分 支 的 基础 ， 
通常 以 格 奥 尔 格 . 坎 托 的 工作 为 标志 ,区 分 不 同 种 类 的 无 限 集 ,其 动机 是 三 角 级 数 的 研 
究 。 无 限 集 理论 的 进一步 发 展 超出 了 离散 数学 的 范围 。 事 实 上 ,当代 的 描述 集合 论 的 工 
作 广 泛 运用 了 传统 的 连续 数学 。 

图 论 即 图 形 和 网 络 的 研究 ,往往 被 认为 是 组 合 数学 的 一 部 分 ,但 已 经 变 得 足够 大 和 清 
晰 ,有 自己 的 问题 ,本 身 就 被 视 为 一 门 学 科 , 它 在 数学 和 科学 的 所 有 领域 都 得 到 推广 应 用 。 
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图 是 离散 数学 研究 的 主要 对 象 之 一 。 它 们 是 目 然 界 和 人 造 结 构 中 最 普 过 的 模型 之 
一 。 它 们 可 以 模拟 物理 ,生物 和 社会 制度 中 的 许多 类 型 的 关系 和 过 程 动 态 。 在 计算 机 科 
学 中 ,它们 代表 通信 BOAR .计算 设备 .计算 流 等 网 络 。 在 数学 中 ,它们 在 几何 和 拓扑 
的 某 些 部 分 (如 纽 结 理论 ) 中 很 有 用 。 代 数 图 理论 与 群 论 有 密切 的 联系 。 还 有 连续 的 图 
f ,但 在 大 多 数 情况 下 ,图 论 的 研究 属于 离散 数学 的 范畴 。 

运 宕 学 提供 了 解决 商业 和 其 他 领域 实际 问题 的 技术 ,如 分 配 资源 以 实现 利润 最 大 化 ， 
或 安排 项 目 活动 ,以 最 大 限度 地 降低 风险 等 问题 。 运 等 学 技术 包括 线性 规划 和 其 他 领域 
的 优化 .排队 理论 .调度 理论 .网络 理论 。 运 拜 学 还 包括 连续 时 间 马 尔 可 夫 过 程 连续 时 间 
BR 马尔 廷 加 莱 斯 ) .过程 优 化 以 及 连续 和 混合 控制 理论 等 连续 性 诬 题 。 

虽然 拓扑 学 属于 数学 领域 , 它 形式 化 概括 了 物体 的 “连续 变形 "的 直观 概念 ,但 它 产 
生 了 许多 离散 的 诛 题 ,这 在 一 定 程度 上 可 归于 对 拓扑 不 变性 的 关注 ,而 拓扑 不 变性 本 身 通 
第 采用 离散 值 。 参 见 组 合 拓扑 .拓扑 图 理论 .拓扑 组 合 .计算 拓扑 离散 拓扑 空间 .有 限 拓 
扑 空间 。 


Text B. $i 


一 个 连通 图 如 果 没 有 包含 简单 的 回路 , 则 称 为 一 棵 树 。 早 在 1857 年 ,英国 数学 家 阿 
we + 由 莱 就 用 树 计算 茶 些 化 合 物 的 可 能 类 型 。 目 那 时 起 , 树 已 被 用 来 解决 各 种 科学 问题 。 

树 在 计算 机 科学 中 特别 有 用 。 例 如 , 树 用 来 构建 高 效 的 在 列表 中 的 定位 算法 。 它 们 
也 用 于 构建 电话 线路 网 络 , 使 数据 存储 和 传送 成 本 最 小 。 树 可 用 于 模拟 决策 的 一 系列 过 
程 ,这 使 得 树 的 排序 算法 研究 具有 非常 高 的 价值 。 

1. 定义 

一 棵 树 是 一 个 无 向 简单 图 G, 满 足以 下 任 一 等 价 条 件 。 

e G 是 连通 的 ,并 且 没 有 回路 。 

e G 没有 回路 ,并 且 添 加 任何 一 条 边 就 会 形成 一 个 回路 。 

。G 是 连通 的 ,并 且 去 掉 任 一 条 边 , 它 就 不 是 连通 图 。 


e G 是 连通 的 ,并 且 不 包含 3 顶点 完全 图 K3 的 子 图 。 
e G 中 的 任意 两 个 顶点 都 可 通过 唯一 的 简单 路 径 连 接 。 
如 果 G 有 有 限 个 顶点 ,就 说 它们 是 n 阶 的 ,那么 上 面 的 命题 也 相当 于 下 列 任 一 条 件 。 


e G 是 连通 的 ,并 具有 (n 一 1 ) 条 边 。 

e G 没有 简单 的 回路 ,并 具有 (n 一 1 ) 条 边 。 

图 3-1 所 示 的 图 形 是 树 吗 ? 

G1 和 G2 都 是 树 ,因为 两 者 都 是 连通 图 ,没有 简单 的 电路 ; G3 不 是 树 , 因 为 e、b 、a、 
d e 是 一 个 简单 的 电路 。 

在 该 图 中 ,最 后 ,G4 不 是 树 ,因为 它 不 是 连通 的 。 


2. 性 质 
(1) nn 个 顶点 的 树 有 (n 一 1 ) 条 边 。 
(2) 一 个 完全 m-SU AGA iPS ARIUS NWA n= mxi+1 个 顶点 。 


(3) 一 个 完全 m- 
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Ci) GA n TTS WARIS im (n —1)/m 和 树叶 数 L=[(m-1)xn+1] 
/m, 

Cd) EA TAMILS WA n = mxi +1 SUA L=(m-1) xi + 1 片 树叶 。 

(ill) 4A L KAH, WA n2 (mx L-1)/(m-1) Wisi FFAG =(L-1)/(m-1) 
个 内 部 顶点 。 

3. 树 的 术语 

(1) m- 叉 树 是 每 一 个 内 部 顶点 的 孩子 数 不 多 于 m 个 的 树 。 

(2) 二 又 树 是 一 个 m- 叉 树 , 仅 当 m= 2 时 (每 个 结 点 仅 有 左 或 右 子 结 点 )。 

(3) 有 序 树 是 一 棵 树 ,其 中 每 个 内 部 顶点 的 孩子 顺序 是 线性 排列 的 。 

(4) 平衡 树 是 一 个 树 高 为 h 的 树 , 其 项 点 所 在 的 子 树 高 为 h 或 h 一 1。 

(5) 二 义 搜索 树 是 一 个 二 又 树 , 知 它 的 左 子 树 不 空 , 则 左 子 树 上 所 有 结 点 的 值 均 小 于 
它 的 根 结 点 的 值 ; 若 它 的 右 子 树 不 空 , 则 右 子 树 上 所 有 结 点 的 值 均 大 于 它 的 根 结 点 的 值 。 

(6) 决策 树 是 有 根 树 ,每 个 顶点 代表 决定 的 可 能 结果 ,叶子 代表 可 能 的 解决 方案 。 

(7) ARM: 包含 图 的 所 有 顶点 的 树 。 

(8) 最 小 生成 树 : 边 的 权重 之 和 最 小 的 生成 树 。 

4. 树 人 遍历 算法 

系统 访问 有 序 根 树 的 每 个 顶点 的 过 程 称 为 遍历 算法 。 下 面 描述 3 种 最 和 常用 的 算法 ， 
EIRT E J .中 序 过 历 和 后 序 忆 有 历 。 

(1) AFJ 

前 序 遍 历 是 递归 定义 的 有 序 根 树 的 顶点 列表 首先 列 出 其 根 结 点 ,其 次 以 从 左 到 右 出 
现 的 顺序 列 出 其 第 一 棵 子 树 ,后面 跟着 其 他 子 树 。 

若 了 是 一 个 包含 根 为 的 有 序 根 树 ,如 果 T 只 由 了 组 成 ,那么 > 是 了 的 前 序 遍 历 。 
否则 ,假设 ,TT,,…,T, 是 T 中 从 左 到 右 的 子 树 , 前 序 遍 历 从 访问 r 开始 ,继续 按 前 序 遍 历 
T, ,然后 按 前 序 遍 历 也 ,以 此 类 推 , 直 到 T 前 序 遍 历 过 。 

(2) FFH 

中 序 遍 历 是 递归 和 定义 的 有 序 根 树 的 顶点 列表 紧 跟 在 第 一 个 子 树 的 后 面 ,后 面 再 跟着 
其 他 子 树 。 它 们 按 从 左 到 右 出 现 的 顺序 让 了 是 有 序 的 根 树 。 

如 果 了 只 由 了 组 成 ,那么 > 就 是 z WFF, ABE T, T, T, Æ T AEE 
右 的 子 树 , 按 中 序 顺序 遍历 从 工 开 始 , 访 问 x, 继续 按 中 序 遍 历 7,、7T,,…, 最 后 中 序 遍 


iT... 

(3) 后 序 遍 历 

后 序 遍 历 是 递归 定义 的 有 序 根 树 的 顶点 列表 按 从 左 到 右 出 现 的 顺序 列 出 子 树 ,然后 
是 根 目录 。 


如 果 了 只 由 了 组 成 , 则 让 了 成 为 根 r 的 有 序 根 树 ,那么 就 是 了 的 后 序 轴 历 。 否 则 ， 
假设 T, ,7T,,…,T, 是 从 左 到 右 的 + 的 子 树 ,后 序 志 历 是 从 也 按 后 序 笛 历 开 始 ,然后 按 后 序 
遍历 T, ,7 ,…, 了 ,最 后 访问 了 结束 。 
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Unit4 软件 工程 
Text A 软件 过 程 


软件 过 程 是 指 生 产 软 件 产品 一 系列 行为 活动 集 。 这 些 活动 集 可 以 包括 应 用 标准 编程 
语言 (如 Java 或 C) 从 设计 草图 开始 的 软件 开发 。 然 而 , 越 来 越 多 的 新 的 软件 开发 是 扩展 
和 修改 已 有 的 系统 或 配置 和 集成 货架 的 软件 或 系统 组 件 。 

像 所 有 智力 产品 和 创新 过 程 一 样 , 软 件 过 程 是 复杂 的 ,依靠 人 做 出 决策 和 判断 。 因 为 
需要 判断 和 创新 ,试图 软件 过 程 自动 化 只 取得 有 限 的 进展 。 计 算 机 辅助 软件 工程 
(CASE) 工 具 可 以 支持 某 些 开发 过 程 行为 。 但 是 ,至 少 在 未 来 的 几 年 中 ,还 没有 可 能 通过 
更 广泛 的 软件 自动 化 代替 软件 过 程 中 工程 师 从 事 的 创意 设计 。 

CASE 工具 的 有 效 性 有 限 ,是 因为 软件 过 程 复杂 多 样 千变万化。 由 于 没有 理想 的 开 
发 过 程 ,许多 企业 组 织 都 开发 了 自身 特点 的 软件 开发 方法 。 工 艺 已 经 发 展 到 利用 企业 组 
织 中 人 的 能 力 , 以 及 所 开发 系统 的 具体 特点 。 对 于 某 些 系统 ,如 关键 的 系统 ,需要 非常 结 
构 化 的 开发 过 程 。 对 商业 系统 ,要 快速 适应 需求 的 变化 ,灵活 敏捷 的 开发 过 程 很 可 能 
有 效 。 

尽管 有 许多 种 软件 过 程 ,但 对 所 有 软件 进程 ,都 存在 一 些 共同 的 基本 行为 活动 。 

(1) 软件 规范 : 定义 软件 的 功能 及 其 操作 上 的 约束 。 

(2) 软件 设计 和 实现 : 将 满足 规范 要 求 的 软件 生产 出 来 。 

(3) 软件 验证 : 必须 验证 软件 是 否 满足 客户 的 需要 。 

(4) 软件 进化 : 软件 必须 不 断 发 展 ,以 满足 不 断 变化 的 客户 需求 。 

没有 “理想 的 ”软件 过 程 ,许多 组 织 都 存在 用 于 改进 软件 过 程 的 框架 。 这 些 过 程 可 能 
包括 过 时 的 技术 或 可 能 在 工业 软件 工程 最 佳 实践 中 不 占 优势 。 事 实 上 ,很 多 企业 组 织 仍 
然 在 他 们 的 软件 开发 中 没有 充分 利用 好 软件 工程 方法 。 

软件 过 程 可 以 通过 过 程 标准 化 减少 不 同 企业 组 织 的 软件 过 程 的 多 样 性 ,这 将 提高 沟 
通 性 ,减少 培训 时 间 ,使 流程 目 动 化 ,也 更 经 济 。 标 准 化 也 是 引进 新 的 软件 工程 方法 和 技 
AR ,进行 良好 软件 工程 实践 的 重要 的 第 一 步 。 

1. 软件 过 程 模型 

软件 过 程 模型 是 软件 过 程 的 抽象 表示 。 每 个 过 程 模型 代表 从 一 个 特定 的 角度 的 过 
程 ,从 而 提供 了 有 关 该 过 程 某 部 分 的 信息 。 本 市 介绍 一 些 很 通用 的 流程 模型 (有 时 被 称 
为 过 程 范例 ) ,并 从 架构 体系 的 角度 呈现 。 也 就 是 说 ,我 们 看 到 的 是 该 过 程 的 框架 ,而 不 
是 具体 活动 的 细节 。 

这 些 通用 模型 不 是 软件 过 程 的 定义 描述 。 相 反 , 它 们 是 可 用 于 解释 不 同 的 软件 开发 
过 程 中 的 抽象 。 你 可 以 把 它们 看 作 过 程 框 架 , 可 扩展 适用 于 更 具体 的 软件 工程 过 程 。 

(1) 瀑布 模型 ,这 种 模型 定义 说 明 开发 ,验证 和 进化 等 基本 过 程 的 行为 活动 ,并 将 它 
们 作为 独立 的 过 程 ,如 需求 说 明 .软件 设计 实现 测试 等 。 

(2) 进化 开发 模型 ,这 种 模型 将 说 明 开发 和 验证 的 活动 交织 在 一 起 。 初 始 系统 是 从 
抽象 的 说 明快 速 开 发 的 ,然后 根据 客户 (需求 ) 输 入 不 断 精 炼 ,产生 满足 客户 需求 的 系统 。 
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(3) 基于 组 件 的 软件 工程 模型 ,这 种 模型 用 于 基于 大 量 可 重用 组 件 的 软件 开发 。 该 
系统 的 开发 过 程 着 重 于 将 这 些 组 件 集成 到 一 个 系统 ,而 不 是 从 头 开 始 开 发 它们 。 

2. 瀑布 模型 

第 一 个 发 布 的 软件 开发 过 程 模型 是 从 更 一 般 化 的 系统 工程 过 程 推导 出 的 ( 萎 斯 莱 
斯 ,1970 年 ) ,如 图 4-1 所 示 。 因 为 一 个 阶段 与 男 一 个 阶段 舱 套 在 一 起 ,所 以 这 种 模式 被 
称 为 瀑布 模型 或 软件 生命 周期 。 模 型 的 主要 阶段 对 应 软件 开发 的 基本 行为 活动 。 

i. 需求 分 析 和 定义 ”通过 与 系统 用 户 协 商 建立 系统 的 服务 约束 和 目标 ,然后 详细 
定义 它们 ,并 作为 系统 的 规范 说 明 。 

li. 系统 和 软件 设计 系统 设计 过 程 中 将 需求 分 配 到 硬件 或 软件 系统 上 。 它 建立 了 
系统 的 整体 架构 。 软 件 设计 包括 识别 和 描述 基本 软件 系统 的 功能 抽象 和 它们 之 间 的 

i. 实现 和 单元 测试 ”这 个 阶段 ,软件 设计 内 容 由 一 组 程序 或 程序 单元 实现 。 单 元 
测试 涉及 验证 每 个 单元 是 否 符 合 其 规范 。 

iv. 集成 和 系统 测试 ”各 个 程序 单元 或 程序 集成 在 一 起 ,构成 一 个 完整 的 系统 进行 
测试 ,以 确保 软件 的 需求 已 得 到 满足 。 经 过 测试 ,该 软件 系统 就 交付 给 客户 。 

V. 操作 和 维护 ”通常 (尽管 不 是 必需 的 ) ,这 是 最 长 的 生命 周期 阶段 。 系 统 安装 并 
投入 实际 使 用 。 维 护 包括 改正 在 生命 周期 的 早期 阶段 没有 被 发 现 的 错误 ,改进 系统 单元 
的 实现 ,在 新 需求 提出 后 增加 系统 的 服务 。 

原则 上 ,每 个 阶段 的 结果 是 经 批准 的 一 个 或 多 个 文档 (签名 关闭 ) 。 后 续 的 阶段 不 应 
该 启动 ,直到 前 一 个 阶段 已 经 完成 。 在 实践 中 ,这 些 阶段 相互 重 琶 ,彼此 间 反 馈 信 息 。 在 
设计 阶段 ,发现 需求 中 的 问题 ;在 编码 中 ,设计 存在 问题 被 发 现 等 。 软 件 过 程 不 是 一 个 简 
单 的 线性 模型 ,而 是 涉及 开发 活动 的 反复 迭代 序列 。 

由 于 文件 制定 和 批准 需要 成 本 ,涉及 明显 返工 的 反复 迭代 工作 代价 大 ,因此 经 过 少量 
反复 迭代 工作 后 ,通常 冻结 部 分 开发 工作 ( 如 说 明 书 ) ,然后 才 继 续 后 面 的 开发 阶段 。 留 
下 的 问题 接 春 细 化 、 忽略 或 编程 规避 。 这 种 过 早 的 需求 冻结 可 能 意味 着 该 系统 将 不 是 用 
户 想 要 的 。 实 现 过 程 的 技巧 规避 也 可 能 导致 严重 的 结构 化 系统 设计 问题 。 

在 最 后 的 生命 周期 阶段 (操作 和 维护 ) ,软件 被 投入 使 用 。 原 始 的 软件 需求 存在 的 错 
误 和 遗漏 将 被 发 现 。 程 序 和 设计 错误 将 涌现 ,新 的 功能 需求 也 将 确立 。 因 此 ,该 系统 必须 
进化 ,以 保持 实用 性 。 进 行 这 些 更 改 ( 软 件 维护 ) 可 能 涉及 重复 前 面 的 过 程 各 个 阶段 。 

瀑布 模型 的 优点 是 文档 在 各 个 阶段 产生 , 它 与 其 他 工程 过 程 模型 相 吻 合 。 其 主要 问 
题 是 在 项 目 中 划分 出 的 不 同 的 阶段 ,其 灵活 性 不 够 。 必 须 在 软件 过 程 的 早期 阶段 给 出 很 
好 的 保证 ,使 得 其 难以 满足 不 断 变 化 的 顾客 需求 。 

因此 ,瀑布 模型 适应 于 在 系统 开发 中 需求 易于 理解 和 不 太 变化 的 项 目 。 

然而 ,瀑布 模型 反映 了 在 其 他 工程 项 目 中 使 用 的 过 程 模型 类 的 特点 。 因 此 ,基于 这 种 
方法 的 软件 过 程 模型 也 用 于 软件 开发 ,特别 是 当 软 件 项 目 是 一 个 更 大 的 系统 工程 项 目的 
一 部 分 时 。 
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Text B UML 简介 


统一 建 模 语言 (UML ) 是 编写 软件 蓝图 的 标准 语言 。UML 可 用 于 软件 密集 型 系统 产 
品 可 视 化 描述 ,规范 .构建 和 文档 化 。 

UML 适合 于 系统 建 模 ,从 企业 信息 系统 到 基于 Web 的 分 布 式 应 用 程序 ,甚至 人 硬 实时 
能 入 式 系统 。 这 是 一 个 非常 传神 的 语言 ,涉及 开发 ,然后 部 署 这 样 的 系统 所 需 的 所 有 方 
Ho BIA UML 功能 强大 ,但 是 它 不 是 很 难 理解 和 使 用 。 要 学 习 使 用 UML ,一 个 有 效 的 
出 发 点 就 是 形成 该 语言 的 概念 模型 ,这 就 要 求学 习 三 大 要 素 : UML 的 基本 结构 块 、 文 配 
这 些 结构 块 如 何 放置 在 一 起 的 规则 以 及 应 用 于 整个 语言 的 一 些 公 用 机 制 。 

由 于 UML 仅 是 一 门 语言 ,因此 它 仅 是 一 种 软件 开发 方法 的 一 部 分 。UML 是 过 程 独 
立 的 ,虽然 对 用 例 驱 动 .以 架构 为 中 心 .迭代 和 增 量 过 程 要 最 佳 化 。 

1. UML 概述 

UML 是 一 门 语言 ,适用 于 可 视 化 ,规范 化 结构 化 文档 化 。 

2. UML 是 一 门 语言 

语言 包括 一 个 词汇 表 以 及 组 合 词 汇 进行 交流 的 规则 。 建 模 语言 是 一 门 语言 , 它 的 词 
汇 表 和 规则 集中 在 一 个 系统 的 概念 和 物理 表示 上 。 建 模 语 言 ( 如 UML ) 是 适合 描述 软件 
蓝图 的 标准 语言 。 

建 模 需要 了 解 一 个 系统 。 没 有 用 哪 一 种 模型 描述 就 足够 了 。 相 反 ,除了 细小 的 系统 ， 
你 经 常 需要 彼此 相关 的 多 个 模型 深入 了 解 (系统 特性 ) 。 对 于 软件 密集 型 系统 ,这 需要 一 
门 语言 从 不 同 的 角度 描述 在 整个 软件 开发 生命 周期 的 系统 的 体系 结构 。 

如 UML 的 词汇 表 和 规则 ,告诉 你 如 何 创 建 和 读 取 结构 良好 的 模型 ,但 它们 不 告诉 
你 ,你 应 该 建立 什么 样 的 模型 ,什么 时 候 应 该 创建 它们 。 那 是 软件 开发 过 程 中 的 功能 。 一 
个 定义 明确 的 过 程 将 指导 你 生产 什么 制品 ,有 什么 活动 和 使 用 什么 样 的 工人 创建 它们 并 
对 其 进行 管理 ,以 及 如 何 使 用 这 些 制品 作为 一 个 整体 评估 和 控制 项 目 (进展 )。 

3. UML 是 可 视 化 语言 

对 于 很 多 程序 员 ,思考 代码 实现 到 具体 编码 之 间 的 距离 接近 雪 。 你 一 边 想 ,一边 编 
码 。 事 实 上 ,有 些 事 情 最 好 直接 由 代码 描述 。 文 字 是 写 表 达 式 和 算法 最 奇妙 的 简洁 和 和 直 
接 的 方式 。 

在 这 些 情景 下 ,程序 员 还 是 在 做 一 些 建 模 工作 ,尽管 比较 弱智 。 他 或 她 甚至 可 能 在 白 
色 板 或 餐巾 纸 上 勾 勒 出 一 些 想法 。 但 是 ,这 样 做 存在 几 个 问题 : 首先 ,与 别人 交流 这 些 概 
念 模型 时 容易 出 错 , 除 非 涉 及 的 人 都 讲 同一 种 语言 。 一 般 情 况 下 ,项 目 组 和 企业 组 织 都 开 
发 他 们 目 己 的 语言 ,如 果 你 是 一 个 局 外 人 或 你 新 加 入 项 目 组 ,就 很 难 理解 发 生 了 什么 事 
情 。 其 次 ,有 关 一 个 软件 系统 的 东西 ,还 存在 一 些 你 无 法 理解 的 事情 ,除非 你 建立 超越 文 
本 编程 语言 模型 。 例 如 ,通过 分 析 层 次 结构 中 的 所 有 类 的 代码 ,可 以 推断 出 类 层次 结构 的 
含义 ,但 不 能 和 耳 接 领会 。 同 样 ,通过 人 研究 系统 的 代码 ,可 以 推断 出 基于 Web 系统 的 对 象 的 
物理 分 布 和 可 能 的 迁移 活动 ,但 不 能 直接 领会 。 其 三 ,如 果 开 发 者 砍 掉 那些 代码 ,对 应 在 
他 或 她 的 脑袋 里 的 模型 又 从 来 没有 写 下 来 ,这 些 信息 将 永远 失去 ,或 者 充其量 只 是 部 分 可 
重建 ,由 开发 者 继续 实现 一 次 。 
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采用 UML 建 模 解 决 了 第 三 个 问题 : 一 个 简明 的 模型 有 利于 沟通 。 

有 些 事情 最 好 以 文本 为 蓝本 ;其 他 的 最 好 图 形 化 建 模 。 事 实 上 ,在 所 有 的 有 意义 的 系 
统 中 ,有 超越 用 编程 语言 表示 的 结构 。UML 就 是 这 样 一 种 图 形 化 的 语言 ,可 解决 上 述 的 
第 二 个 问题 。 

UML 不 仪 仅 是 一 堆 图 形 符 号 集 。 相 反 , 在 UML 每 个 符号 的 背后 ,具有 一 个 良好 定 
义 的 语义 。 在 这 种 方式 下 ,一 个 开发 人 员 可 以 编写 UML 模型 , 另 一 名 开发 人 员 ,甚至 其 
他 工具 ,可 以 无 疏 异 地 解释 该 模型 。 这 就 解决 了 上 述 的 第 一 个 问题 。 

4. UML 是 实现 规范 化 的 语言 

本 文中 ,规范 化 的 意思 是 建立 精确 的 、 明 确 的 和 完整 的 模型 。 特 别 是 ,UML 解决 了 在 
开发 和 部 署 软件 密集 型 系统 需要 进行 的 所 有 重要 的 分 析 设计 和 实现 决策 的 规范 化 问题 。 

5. UML 是 一 种 结构 化 语言 

UML 不 是 一 种 可 视 化 的 编程 语言 ,但 它 的 模型 可 以 直接 关联 到 各 种 编程 语言 。 这 意 
味 着 , 它 可 以 从 UML 模型 映射 到 编程 语言 ,如 Java C++ E% Visual Basic ,甚至 映射 到 关系 
数据 库 中 的 表 或 面 回 对 象 的 数据 库 永 久 存 储 对 象 。 在 UML 中 ,事情 最 好 用 图 表 表 示 ,而 
在 编程 语言 中 ,事情 最 好 用 文本 表达 。 

这 个 映射 允许 从 UML 模型 到 编程 语言 的 正 癌 工程 中 生成 代码 。 反 过 来 也 是 可 能 
的 : 你 可 以 从 代码 实现 到 UML 建立 模型 。 逆 向 工程 不 是 魔术 ,除非 你 在 执行 中 对 信息 进 
行 编码 ,否则 在 模型 转换 代码 时 ,信息 就 丢失 了 。 逆 向 工程 需要 与 人 机 交互 作用 工具 的 支 
持 。 结 合 正 问 工程 代码 生成 和 逆 癌 工程 这 两 条 途径 ,就 可 以 产生 双 问 工程 ,这 意味 着 既 能 
在 图 形 视图 下 工作 ,也 可 以 在 文本 视图 下 工作 ,只 要 用 工具 保持 二 者 的 一 致 性 即 可 。 

除了 这 种 直接 的 映射 ,UML 还 有 足够 的 和 明确 的 表现 力 , 人 允许 直 接 描述 模型 .系统 仿 
真 和 运行 系统 检测 。 

6. UML 是 一 种 文档 化 语言 

一 个 恨 好 的 软件 企业 除了 提供 可 执行 的 代码 外 ,还 可 以 生产 各 种 各 样 的 智力 产品 。 
这 些 产品 包括 (但 不 限于 ) 需 求 、 架 构 设计、 源 代码 项目 计划 .试验 .原型 dg. 

根据 不 同 的 开发 习惯 ,这 些 产品 为 越 来 越 多 的 人 所 需要 , 虽 不 是 正式 的 。 这 样 的 产品 
不 仅 是 一 个 项 目的 可 交付 成 果 , 也 是 软件 系统 开发 和 部 署 后 进行 控制 、 检 测 和 交流 的 
关键 。 

UML 强调 系统 的 体系 结构 文档 及 其 所 有 的 细节 。UML 是 满足 测试 需求 的 描述 语 
言 。 最 后 ,UML 也 是 满足 项 目 规划 和 发 布 管理 等 活动 所 需 的 建 模 语言 。 


Unit5 Zi dE HE 
Text A MySQL 简介 


MySQL 25:05 Fe ACE POL HAS sie SY, ES EOE EIR S D. HRS diee 
PROT VEBUEE Y, Fe PEE AS EP PE, TEC ,它们 使 用 结构 化 查询 语言 (SQL ) 
语句 传达 你 的 意图 到 服务 侨 。 客 户 端 程序 安装 在 本 地 的 你 要 访问 MySQL 的 机 船上 ,但 
服务 融 可 以 在 任何 地 方 进行 安 半 , 只 要 客户 端 可 以 连接 到 它 。MYyYSQL 是 一 种 固有 的 联网 
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数据 库 系统 ,以 便 客户 端 可 以 与 服务 需 进 行 通信 ,服务 器 可 以 运行 在 本 地 计算 机 或 其 他 地 
方 的 机 器 上 ,也 可 能 在 地 球 的 另 一 边 。 客 户 机 可 以 因 许 多 不 同 的 功能 需要 而 编写 ,但 每 一 
个 连接 到 服务 器 的 交互 过 程 ,包括 发 送 SQL 语句 到 服务 器 执行 数据 库 操作 ,并 从 它 接收 
该 语句 的 结果 。 

这 样 的 一 个 MySQL 程序 客户 端 包含 在 MySQL 发 布 包 中 。 当 交互 使 用 时 , MySQL 
提示 你 输入 语句 ,将 其 发 送 到 MySQL 服务 器 执行 ,然后 显示 结果 。 这 种 功能 非常 有 用 ， 
使 MySQL 具有 自己 的 特色 ,但 它 也 是 一 个 宝贵 的 工具 ,通过 MySQL 编程 活动 帮助 你 。 
这 往往 便于 从 一 个 脚本 程序 内 快速 查看 访问 表 结 构 , 在 程序 中 使 用 它 之 前 尝试 一 条 语句 ， 
确保 它 产生 一 种 正确 的 输出 ,等 等 MySQL 非常 适合 做 这 些 工 作 。 MySQL 也 可 以 非 交互 
使 用 ,例如 从 文件 中 或 从 其 他 程序 语句 读 取 。 这 使 你 可 以 将 MySQL 使 用 在 脚本 中 或 时 
钟 进程 中 或 与 其 他 应 用 程序 相 结 合 。 

通过 本 章 的 介绍 ,就 可 以 更 有 效 地 使 用 MySQL 的 功能 。 

e 启动 和 停止 MySQL, 

e 指定 连接 参数 ,并 使 用 选项 文件 。 

e 设置 PATH 变量 ,以 便 你 的 命令 解释 大 能 找到 MySQL( 和 其 他 MySQL 程序 ) 。 

e 交互 发 出 SQL 语句 和 使 用 批 处 理 文件 。 

。 取消 和 编辑 语言 命令 。 

e 控制 MySQL 的 输出 格式 。 

要 使 用 所 示 的 例子 ,需要 一 个 MySQL 用 户 账户 和 一 个 工作 数据 库 。 本 章 的 前 两 部 
分 描述 了 如 何 使 用 MySQL 设置 这 些 。 为 达到 演示 目的 ,假设 你 使 用 的 MySQL 例子 
如 下 。 

© MySQL 服务 需 在 本 地 主机 上 运行 。 

e 你 的 MySQL 用 户 名 和 密码 分 别 是 cbuser 和 cbpass。 

e 你 的 数据 库 名 为 cookbook. 

对 你 自己 的 实验 ,可 以 违背 这 些 假设 。 您 的 服务 器 不 必 本 地 运行 ,并 且 无 须 使 用 在 本 
章 使 用 的 用 户 名 密码 或 数据 库 名 称 。 自 然 ,如 果 你 的 系统 上 使 用 的 是 不 同 的 默认 值 ,就 
需要 修改 例子 的 对 应 内 容 。 

即使 不 使 用 cookbook 作为 你 的 数据 库 名 称 ,建议 你 创建 一 个 专用 数据 库 专门 尝试 这 
个 例子 ,而 不 是 在 你 目前 用 作 其 他 用 途 的 数据 库 进 行 和 尝试 。 否 则 , 现 有 表 的 名 称 可 能 与 范 
例 中 的 名 称 冲突 ,你 必须 做 出 修改 , 当 你 使 用 一 个 单独 的 数据 库 时 ,就 不 必要 了 。 

如 果 你 有 最 喜欢 用 于 发 出 查询 的 另 一 个 客户 端 程 序 ,本 章 中 的 一 些 概念 可 能 不 适用 。 
例如 ,你 可 能 更 喜欢 图 形 化 MySQL 查询 浏览 副 的 程序 , 它 提供 了 一 个 点 击 鼠 标 界面 的 
MySQL 数据 库 。 在 这 种 情况 下 ,一些 原则 将 是 不 同 的 ,如 你 终止 SQL 语句 的 方式 。 TE 
MySQL 中 ,终止 语句 用 分 号 ( ; ) 字符 ,而 在 MySQL 查询 浏览 器 中 有 “终止 语句 ”的 执行 
按钮 。 男 一 种 流行 的 界面 是 phpMyAdmin, 它 使 你 能 够 通过 Web 浏览 硕 访 问 MySQL, 


Text B 执行 事务 


因为 MySQL 服务 天 是 多 线程 ,所 以 它 可 以 在 同一 时 间 处 理 多 个 客户 端 请 求 。 为 了 
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应 对 客户 端 之 间 的 争夺 ,服务 硕 对 两 个 客户 端 不 能 同时 修改 同一 数据 进行 任何 必要 的 锁 
mE, SRI, MARS AT SQL 语句 时 , 它 很 可 能 是 连续 地 从 给 定 的 客户 机 接收 语句 ,并 与 
来 自 其 他 客户 端的 语句 交织 在 一 起 。 如 果 客 户 端 发 送 的 多 条 语句 彼此 依赖 ,事实 上 ,其 他 
客户 端 执 行 这 些 语句 更 新 的 数据 表 就 会 陷 人 困境 。 如 果 多 条 语句 的 操作 不 能 运行 到 完 
成 ,语句 失败 也 可 能 会 有 问题 。 假 设 你 有 一 个 包含 有 关 航 空 公司 航班 安排 信息 的 飞行 表 ， 
你 想 从 那些 可 用 的 人 员 中 选择 一 个 飞行 员 , 更 新 航班 578 记录 。 你 可 以 使 用 如 下 3 条 
语句 。 

SEIFCT @p val := pilot id FROM pilot WHERE available = 'yes' LIMIT 1; 

UPDATE pilot SET available = 'no' WHERE pilot id = Q8 p val; 

UPDATE flight SET pilot id = @p val WHERE flight id = 578; 

第 一 条 语句 选择 一 个 可 用 飞行 员 , 第 二 条 语句 标记 其 为 不 可 用 ,第 三 条 语句 将 该 飞行 
员 分 配 到 该 航班 。 这 在 实践 中 足够 直截了当 ,但 在 原理 上 ,这 个 过 程 存 在 一 系列 问题 : 

如 果 两 个 客户 要 安排 飞行 员 , 可 能 他 们 都 将 运行 初始 的 SELECT 查询 语句 ,在 设置 
飞行 员 的 状态 为 不 可 用 之 前 ,他 们 有 机 会 检索 到 相同 的 飞行 员 ID 号 。 如 果 出 现 这 种 情 
况 ,同一 飞行 员 就 会 被 立刻 安排 到 两 个 航班 上 。 

这 三 条 语句 必须 作为 一 个 整体 成 功 执行 。 例 如 ,如 果 SELECT 语句 和 第 一 条 
UPDATE 语句 成 功 运 行 ,但 第 二 条 UPDATE 语句 失败 , 则 飞行 员 的 状态 设置 为 不 可 用 ,而 
又 没有 将 飞行 员 分 配 到 一 个 航班 。 该 数据 库 将 处 于 不 一 致 的 状态 。 

为 了 防止 在 这 类 情况 下 的 并 发 性 和 完整 性 问题 ,事务 ( 处理) 概念 是 有 帮助 的 。 一 个 
事务 是 一 组 语句 ,并 确保 以 下 特性 : 

e 在 事务 过 程 中 没有 其 他 客户 端 可 以 更 新 在 事务 处 理 中 使 用 的 数据 。 例 如 , 当 你 预 
订 航 班 飞行 员 时 ,其 他 客户 不 能 修改 飞行 员 或 飞行 记录 。 在 你 执行 操作 时 ,通过 
防止 其 他 客户 干扰 ,事务 处 理解 决 了 MySQL 服务 器 多 用 户 而 产生 的 并 发 问题 。 
事务 处 理 串 行 化 多 条 语句 操作 访问 共享 资源 。 

e 事务 中 的 语句 组 成 为 一 个 单位 提交 起 作用 (生效 ) , 当 且 仅 当 他 们 全 部 成 功 时 。 如 
果 发 生 错 误 ,错误 前 面 发 生 的 任何 动作 被 回 滚 , 留 下 相关 的 表 不 受 影响 ,就 好 像 根 
本 没有 任何 语句 发 出 一 样 。 这 样 可 以 保证 数据 库 不 会 变 得 不 一 致 。 例 如 ,如 果 一 
个 更 新 航班 表 语 句 失败 , 回 滚 导 致 改变 飞 行 员 表 操作 撤销 ,而 使 驾驶 员 仍 然 可 用 。 
回 滚 操作 使 得 你 不 必 清 楚 如 何 撤销 部 分 已 完成 的 操作 。 


Unit 6 RAHA 
Text A ”什么 是 嵌入 式 系统 


过 去 几 十 年 ,一 个 令 人 怀 讶 的 发 展 是 计算 机 在 人 类 事物 中 崛起 占 主导 位 置 。 今 天 ,在 
我 们 的 家 庭 和 办 公 室 ,计算 机 台数 已 比 生 活 和 工作 其 中 的 人 数 更 多 。 然 而 ,许多 计算 机 都 
没有 被 它们 的 用 户 看 出 来 。 本 单元 将 解释 什么 是 通信 式 系统 ,在 哪里 可 以 找到 它 ,还 将 介 
绍 藤 入 式 编程 的 知识 ,解释 为 什么 本 书 选 择 使 用 C 和 C++ 语言 ,描述 范例 中 所 使 用 到 的 
使 件 。 
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1. A THENGURSE 

藤 入 式 系统 是 计算 机 人 硬件 和 软件 ,以 及 可 能 的 附加 机 械 或 其 他 部 件 设 计 成 执行 特定 
功能 的 组 合 。 一 个 很 好 的 例子 是 微波 炉 。 几 乎 每 家 每 户 都 有 一 个 微波 炉 , 数 以 千 万 计 的 
人 每 天 都 在 使 用 它 ,但 很 少 有 人 意识 到 ,一 个 处 理 侣 和 软件 都 参与 了 他 们 的 午餐 或 晚餐 的 
准备 工作 。 

与 家 用 的 个 人 计算 机 对 比 , 它 也 是 由 计算 机 人 硬件 和 软件 ,以 及 机 械 部 件 ( 如 磁盘 驱动 
般 ) 组 成 。 然 而 ,个 人 计算 机 不 设计 成 执行 特定 的 功能 。 相 反 , 它 能 够 做 许多 不 同 的 事 
情 。 许 多 人 使 用 通用 计算 机 这 个 词 进行 明确 的 区 分 。 装 货 时 ,通用 计算 机 处 于 一 个 空白 
状态 ;制造 商 不 知道 客户 将 用 它 做 什么 。 一 个 客户 可 能 会 用 它 作 网 络 文件 服务 需 , 另 一 个 
客户 可 能 用 它 玩 游戏 ,第 三 个 客户 可 能 用 它 编写 下 一 部 宏伟 的 美国 小 说 。 

通 笛 ,一 个 散人 式 系统 是 一 些 较 大 系统 的 一 个 部 件 。 例 如 ,现代 汽车 和 卡车 包含 许多 
租 人 式 系 统 。 一 个 通信 式 系统 控制 防 抱 死 制 动 系统 , 另 一 个 艇 人 式 系 统 监视 并 控制 车 辆 
的 排放 量 ,第 三 个 通 人 式 系统 在 仪表 板 显 示人 信息。 在 某 些 情况 下 EASA Sti WE 
种 通信 网 络 连 接 起 来 ,但 这 当然 不 是 必需 的 。 

这 可 能 令 你 迷惑 ,必须 指出 ,一 个 通用 计算 机 本 和 号 就 是 由 大 量 的 舱 入 式 系 统 组 成 的 。 
例如 ,我 的 计算 机 由 键盘 、 鼠 标 、 视 频 卡 .调制 解 调 硕 、 便 盘 驱 动 硕 、 软 盘 驱 动 硕 和 声卡 组 
成 ,它们 每 一 个 都 是 舱 入 式 系 统 。 这 些 设备 都 包括 处 理 帮 和 软件 ,并 且 设 计 成 执行 特定 的 
功能 。 例 如 ,调制 解 调 需 被 设计 成 通过 模拟 电话 线 发 送 和 接收 数字 数据 。 就 是 这 样 而 已 。 
和 所 有 其 他 设备 一 样 ,可 以 概括 成 一 句 话 。 

如 果 一 个 般 入 式 系 统 设计 得 很 好 ,所 用 设备 的 用 户 可 能 完全 感觉 不 到 处 理 帮 和 软件 
的 存在 ,如 微波 炉 、VCR 或 闹钟 。 在 某 些 情 况 下 ,其 至 有 可 能 建造 一 个 不 包含 处 理 侣 和 软 
件 的 等 效 设 备 。 这 可 以 通过 定制 的 集成 电路 取代 执行 相同 功能 的 人 硬件 组 合 完 成 。 然 而 ， 
当 设 计 成 这 种 方式 的 硬件 时 ,会 丢失 很 大 的 灵活 性 。 比 起 重新 设计 一 块 定制 的 硬件 ,改变 
几 行 软件 代码 很 容易 .更 便宜 。 

2. 历史 与 未 来 

直到 1971 年 ,第 一 个 这 样 的 系统 才 出 现 。 那 年 ,英特尔 推出 了 全 球 第 一 个 微 处 理 需 。 
its Fr 4004 被 设计 成 在 日 本 Busicom 公司 生产 的 商务 计算 天 使 用 。1969 年 ,Busicom 要 求 
英特尔 设计 出 一 套 定 制 的 集成 电路 ,使 用 在 它们 的 新 计算 各 模型 上 。4004 心 片 是 英特尔 
公司 对 需求 的 回应 。 而 不 是 为 每 个 计算 大 设计 定制 硬件 ,英特尔 建议 ,一 个 通用 电路 可 以 
在 整个 计算 需 行 业 中 使 用 。 这 种 通用 处 理 需 设计 成 读 取 和 执行 一 组 指令 的 软件 ,存储 在 
外 部 的 存储 芯片 中 。 英 特 尔 的 想法 是 ,该 软件 可 以 给 每 台 计 算 需 其 独特 的 功能 

这 个 微 处 理 各 一 夜 成 名 , 它 的 应 用 在 随后 的 十 年 稳步 增长 。 最 早 的 艇 入 式 应 用 包括 
无 人 罗 驶 的 空间 探测 融 .计算 机 操作 的 交通 信号 灯 , 以 及 飞机 的 飞行 控制 系统 。20 世纪 
80 年 代 , 通 入 式 系统 悄悄 踏 痢 微 计 算 机 时 代 的 巨 浪 将 微 处 理 需 融 到 我 们 个 人 和 职业 生活 
的 每 一 个 角落 。 许 多 电子 设备 用 在 厨房 (面包 机 食品 加 工作 和 微波 炉 ) .起 居室 (电视 
DL Er Mal AE FE at) 和 工作 场所 (传真 机 、 寻呼机 激光 打印 机 收银 机 和 信用 卡 旋 卡 需 ) 的 
RARR, 

KARRAR AERE, RAAT, BAAS OGHA AB ATH aie 
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JJ SEES p ng Ern se TE RL Be dil T FPG A fs Ifa ait, 2542 3 SINAI EAE A E 
BUZWILANIETI FEY Be CUR T 3EAO INI] T BS ACE BEL ( PDAs) ,数码 相 
机 和 仪表 板 导 航 系统 。 显 然 ,将 来 相当 长 的 一 段 时 间 , 358 UJ; BE PS A DIR EY RRA 
式 系统 的 技能 和 期 望 。 

3. 实时 系统 

这 一 舱 入 式 系统 的 子 类 是 值得 介绍 的 。 如 通常 定义 的 实时 系统 是 具有 时 间 约 束 的 计 
算 机 系统 。 换 言 之 ,一 个 实时 系统 中 的 某 些 计算 或 决策 能 力 是 与 时 间 紧 密 设 定 的 。 这 些 
重要 的 计算 据说 有 完成 的 截止 时 间 要 求 。 而 且 , 对 于 所 有 的 实际 应 用 ,错过 截止 时 间 与 一 
个 错误 的 答案 一 样 糟糕 。 

如 果 一 个 截止 时 间 错 过 了 ,会 发 生 什 么 问题 ,这 是 一 个 关键 问题 。 例 如 ,如 果实 时 系 
统 是 飞机 的 飞行 控制 系统 的 一 部 分 ,单一 错过 截止 时 间 问 题 , 它 有 可 能 给 乘客 和 机 组 人 员 
的 生命 带 来 威胁 。 然 而 ,如 果 所 涉及 的 系统 是 卫星 通信 ,损害 可 能 被 限制 在 单个 损坏 的 数 
据 包 。 越 严重 的 后 果 ,就 越 有 可 能 说 截止 时 间 是 “ 硬 ” 的 ,因此 ,该 系统 是 便 实 时 系统 。 在 
时 间 连 续 的 另 一 问 实 时 系统 ,就 认为 具有 ”" 软 ”的 截止 时 间 。 

一 个 实时 系统 的 设计 者 必须 在 他 的 领域 更 加 勤奋 工作 。 他 必须 保证 在 所 有 可 能 的 条 
件 下 ,软件 和 硬件 可 靠 地 运行 ,并 且 对 人 的 生命 依赖 于 系统 的 正确 执行 程度 ,必须 通过 工 
程 计算 和 文字 描述 加 以 论证 来 确保 。 


Text B 认识 硬件 


其 入 式 软件 工程 师 在 日 己 的 职业 生涯 中 会 有 机 会 与 许多 不 同 的 人 硬件 一 起 工作 。 在 本 
草 中 ,我 会 教 你 一 个 简单 过 程 ,我 是 如 何 熟 悉 新 的 电路 板 的 。 在 这 个 过 程 中 ,我 会 指导 你 
通过 创建 一 个 头 文件 描述 主板 最 重要 的 特点 和 初始 化 硬件 到 已 知 状态 的 软件 。 

1. SRA 

编写 舱 入 式 系 统 软件 之 前 ACE TE E35 11H] BRPE, IC Ha EY EARS 
的 一 般 操作 。 不 需要 了 解 硬 件 的 每 一 个 细 方 ;那些 知识 不 会 立刻 就 需要 ,会 随 看 时 间 的 推 
Te MPAA o 

每 当 收 到 一 个 新 电路 板 ,你 应 该 花 一 些 时 间 阅 读 它 提供 的 所 有 文档 。 如 果 电 路 板 是 
一 个 现成 的 产品 , 它 可 能 伴随 有 充分 考虑 了 软件 开发 人 员 需 求 的 “用 户 手册 ”或 “程序 员 
手册 ”。 但 是 ,如 果 这 个 电路 板 是 为 你 的 项 目 定制 设计 的 ,该 文档 可 能 会 更 神秘 或 主要 为 
人 硬件 设计 师 参 考 而 写 。 无 论 哪 种 方式 ,这 (阅读 文档 资料 ) 是 你 开始 工作 的 最 好 地 方 。 

当 正 在 阅读 文档 时 ,请 将 电路 板 放 在 一 边 。 这 将 有 助 于 你 专注 大 局 。 读 完 文档 后 你 
会 有 充足 的 时 间 更 仔细 地 检查 实际 的 电路 板 。 拿 起 电路 板 前 ,应 该 能 够 回 谷 有 关 它 的 两 
个 基本 问题 。 

e 电路 板 的 总 体 功能 是 什么 ? 

e. 数据 如 何 通 过 它 ( 交换 )? 

例如 ,假设 你 是 调制 解 调 融 设计 团队 中 的 一 员 。 你 是 软件 开发 人 员 ,刚刚 从 硬件 设计 
师 那 里 收 到 早期 原型 板 。 因 为 你 已 经 熟悉 了 调制 解 调 各 ,对 你 而 言 , 它 的 总 体 功 能 和 通过 
的 数据 流 应 该 是 相当 清楚 的 。 板 子 的 目的 是 通过 模拟 电话 线 发 送 和 接收 数字 数据 。 便 件 
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从 一 组 电气 连接 中 读 取 数字 数据 和 写 人 模拟 形式 的 数据 到 连接 的 电话 线路 上 。 数 据 流 还 
存在 相反 的 方向 ,从 电话 线 插 口 读 入 模拟 数据 和 输出 数字 数据 。 

虽然 大 多 数 系 统 的 功能 是 相当 明显 的 ,但 是 数据 流 可 能 不 是 。 我 经 常 发 现 一 个 数据 
流 方 框图 对 实现 快速 理解 是 有 帮助 的 。 如 果 你 很 幸运 ,提供 给 你 的 硬件 文档 将 包含 你 所 
需要 的 框图 的 一 个 超 集 。 然 而 ,你 可 能 仍然 发 现 创 建 自 己 的 数据 流 图 还 是 有 用 的 。 这 样 ， 
你 可 以 忽略 系统 中 与 基本 数据 流程 不 相关 的 人 硬件 组 件 。 

对 于 Arcom 公司 生产 的 板子 ,该 硬件 设计 时 没有 考虑 到 一 个 特定 的 应 用 。 因 此 ,对 
于 本 章 的 剩余 部 分 ,我们 将 不 得 不 想象 , 它 确实 有 一 个 目的 。 我 们 应 当 假定 该 电路 板 设计 
用 作 打 印 机 共享 设备 。 打 印 机 共享 设备 允许 两 台 计 算 机 共享 一 台 打 印 机 。 

该 装置 的 用 户 连接 计算 机 到 每 个 串口 和 一 台 打 印 机 连 到 并 行 口 。 然 后 两 台 计 算 机 都 
可 以 将 文档 发 送 到 打印 机 ,虽然 某 一 时 刻 只 能 有 一 台 计 算 机 可 以 运行 。 

为 了 说 明 数 据 是 如 何 通 过 打印 机 共享 设备 流动 的 ,可 以 画 框 图 ,如 图 6-1 rz (cil 
出 了 所 涉及 本 应 用 的 Arcom 板子 上 的 那些 硬件 装置 ) 。 通 过 查看 框图 ,你 应 该 能 够 将 通 
过 该 系统 的 数据 流 快速 可 视 化 。 要 打印 的 数据 从 任 一 串口 接收 ,保存 在 RAM 中 ,直到 打 
印 机 准备 接收 更 多 的 数据 ,并 通过 并 行 端口 传送 到 打印 机 。 实 现 这 一 切 功 能 的 软件 都 存 
RETE ROM 中 。 

一 旦 创建 了 一 个 框图 ,不 要 弄 皱 并 把 它 扔 掉 ,应 该 把 它 放 好 ,在 整个 项 目 中 ,你 都 可 以 
参考 它 。 建 议 创建 一 个 项 目 笔记 本 ,或 将 其 粘 在 第 一 页 上 。 随 着 你 继续 使 用 这 块 硬件 板 ， 
在 笔记 本 上 写 下 你 所 了 解 的 一 切 。 你 可 能 还 希望 保存 有 关 软 件 设计 和 实现 的 记录 。 项目 
笔记 本 是 有 价值 的 ,不 仅 在 你 正在 开发 软件 时 ,而 且 在 该 项 目 已 完成 后 。 几 个 月 或 几 年 
后 , 当 你 需要 更 改 你 的 软件 ,或 处 理 类 似 的 硬件 时 ,你 将 感激 你 付出 额外 的 努力 ,记录 到 笔 
eA 

2. 检查 外 观 

设想 自己 处 在 处 理 需 的 位 置 一 会 儿 , 往 往 是 有 益 的 。 毕 竟 ,处 理 器 最 终 只 会 做 你 的 软 
件 指 示 它 做 的 。 想 象 一 下 处 理 器 是 什么 样 的 : 处 理 需 的 世界 会 是 什么 样子 ? 如 果 从 这 个 
角度 想 ,你 很 快意 识 到 一 件 事 是 ,处 理 器 有 很 多 伙伴 。 这 些 都 是 电路 板 上 的 其 他 硬件 部 
分 ,与 该 处 理 需 可 以 直接 通信 。 在 本 节 中 ,你 将 学 会 识别 它们 的 姓名 和 地 址 。 

首先 要 注意 的 事情 是 ,有 两 种 基本 类 型 : fef MIN. WA. fefta HT GS RUN 
码 存储 和 检索 。 但 你 可 能 想 知 道外 设 是 什么 。 这 些 专 门 的 硬件 设备 ,要 么 通过 (IO ) 与 
外 面 的 世界 相互 作用 ,或 者 执行 特定 的 硬件 功能 。 例 如 ,在 艇 入 式 系统 中 ,两 个 最 常见 的 
外 设 是 串 行 端口 和 定时 器 。 前 者 是 一 个 IO 设备 ,后 者 基本 上 是 一 个 计数 器 。 

Intel 的 80x86 的 成 员 和 其 他 一 些 处 理 需 家族 有 两 个 不 同 的 地 址 空间 ,通过 它们 可 以 
在 存储 器 和 外 设 间 进 行 通 信 。 第 一 类 地 址 空间 称 为 存储 器 空间 ,并 主要 用 于 存储 器 装置 ; 
第 二 类 只 保留 给 外 围 设备 , 称 为 LO 空间 。 然 而 ,外 围 设 备 也 可 以 位 于 存储 融 空 间 内 ,由 
硬件 设计 者 决定 。 当 这 种 情况 发 生 时 ,我们 说 这 些 外 设 是 内 存 映射 。 

从 处 理 器 的 角度 看 ,内 存 映射 外 设 的 外 观 和 行为 非常 像 存 储 设备 。 然 而 ,外 围 设 备 的 
功能 很 明显 与 一 个 存储 需 的 作用 不 同 ,并 不 是 简单 的 存储 提供 给 它 的 数据 ,外 设 可 能 代替 
数据 解释 为 命令 ,或 以 某 种 方式 处 理 数据 。 如 果 外 设 位 于 存储 空间 内 ,我 们 就 说 系统 内 存 
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映射 LO. 

BON GRIPE B EET UA, o ETE R SEAE HAFA RS LAO ,因为 对 人 硬件 和 软件 开发 者 都 
有 优势 。 它 对 硬件 开发 者 有 吸引 力 ,因为 它 可 能 消除 I/O 空间 ,及 其 相关 联 的 一 些 导线 。 
这 不 仅 可 显著 降低 电路 板 的 生产 成 本 ,也 可 降低 硬件 设计 的 复杂 度 。 对 程序 员 内 存 映射 
的 外 设 也 是 有 益 的 ,能 够 使 用 指针 、 数 据 结构 和 联合 体 ,更 容易 、 更 有 效 地 与 外 设 进行 


交互 。 
Unit 7 计算 机 网 络 
Text A 因特网 协议 族 


因特网 ( Internet) 协 议 族 是 一 组 用 于 互联 网 和 其 他 类 似 网 络 的 通信 协议 。 它 通常 也 
称 为 TCP/IP, 取 自 两 个 最 重要 的 协议 命名 : 传输 控制 协议 (TCP) 和 网 际 协议 (全) ,这 是 
在 该 标准 中 定义 的 前 两 个 网 络 协议 。 现 代 IP 网 络 的 代表 始 于 20 世纪 60 年 代 和 70 年 
代 ,20 世纪 80 年 代 演 变 出 互联 网 和 局 域 网 ,20 世纪 90 年代 初 出 现 万 维 网 网 站 。 

互联 网 协议 族 像 许 多 协议 族 , 由 多 层次 组 成 。 每 一 层 解决 涉及 数据 的 一 组 传输 问题 。 
特别 是 ,每 层 定义 层 内 协议 的 操作 范围 。 

通常 , 某 层 的 组 件 为 上 层 协 议 提 供 定 义 明确 的 服务 ,并 且 服 务 可 来 自 其 低层 的 服务 。 
上 层 罗 辑 上 贴近 用 户 和 处 理 更 抽象 的 数据 ,依靠 低层 协议 翻译 ,将 数据 转换 成 最 终 适 宜 物 
理 传 输 的 形式 。 

TCP/IP 模型 包括 4 层 , 从 低 到 高 依次 是 链 路 层 、 网 络 层 传输 层 以 及 应 用 层 。 

1. 发 展 史 

互联 网 协议 族 源 于 1970 年 初 美国 国防 高 级 研究 计划 局 (DARPA ) 进行 的 研究 和 开 
发 。1973 年 春天 ,已 有 的 ARPANET 网 络 控制 程序 (NCP) 协 议 的 开发 者 温 顿 . TESTA, 
了 卡 恩 主持 的 开放 式 架 构 互 连 模 型 工作 组 ,以 设计 下 一 代 ARPANET 协议 为 目标 。 

截至 1973 年 夏天 , 卡 因 和 总 夫 曾 利用 公共 互联 网 络 协议 重新 塑造 了 一 个 基本 的 网 
络 , 其 隐藏 网 络 协议 之 间 的 差异 性 ,而 其 可 徘 性 不 由 网 络 提供 ,如 在 ARPANET 中 ,是 由 主 
机 负责 的 。 

1975 年 ,在 斯 坦 福 大 学 和 伦敦 大 学 学 院 (UCL ) 两 网 之 间 进 行 了 TCP/IP 通信 测试 。 
1977 年 11 月 ,在 美国 \ 身 国 和 挪威 站 点 之 间 进 行 了 3 个 TCP/IP 网 络 互联 的 试验 。 
1978—1983 年 ,多 个 人 研究 中 心 开 发 了 其 他 一 些 TCP/IP 原型 。1983 年 1 H 1 日 , 当 新 的 协 
议 正式 开发 完成 后 就 永久 激活 ,ARPANET 迁移 到 TCP/IP, 

1982 年 3 月 ,美国 国防 部 宣布 TCP/IP 作为 所 有 军用 计算 机 网 络 的 标准 。1985 年 , 互 
联网 架构 委员 会 为 计算 机 行业 举办 了 为 期 三 天 有 关 TCP/IP 的 研讨 会 ,250 个 供应 商 代表 
出 席 ,促进 协议 推广 ,引领 其 日 益 增长 的 商业 应 用 。 

2. 各 层 互 联网 协议 

TCP/IP 协议 族 对 提供 的 协议 和 服务 进行 了 抽象 封装 。 这 样 的 封装 通常 使 协议 族 对 
应 每 一 功能 层 进 行 划 分 。 一 般 地 ,应 用 程序 (该 模型 的 最 高 级 别 ) 使 用 一 组 协议 向 下 一 层 
发 送 其 数据 ,在 下 一 层级 进一步 封装 。 
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这 可 以 通过 一 例 网 络 情景 进行 说 明 ,其 中 两 个 因特网 计算 机 主机 跨越 本 地 网 的 边界 ， 
即 互联 网 络 网 关 ( 路 由 需 ) 进 行 通信 ,如 图 7-1 所 示 。 

协议 和 方法 的 功能 组 在 应 用 层 传输 层 .因特网 层 以 及 链 路 层 。 这 个 模型 不 打算 成 为 
一 个 严格 的 参考 模型 ,而 使 用 必须 适合 成 为 标准 的 新 协议 。 封 装 的 应 用 层 数 据 问 下 通过 
的 协议 栈 如 图 7-2 所 示 。 

表 7-2 提供 了 在 各 分 层 对 应 各 自 协 议 族 的 一 些 例子 。 

3. 实现 

现今 使 用 的 大 多 数 计 算 机 操作 系统 ,包括 所 有 的 普通 消费 定位 的 系统 ,都 有 一 个 
TCP/IP 实现 。 最 少 可 接受 的 实现 包括 实现 (从 最 必需 的 到 不 太 重 要 的 )IP、ARP ICMP, 
UDP,TCP 和 某 个 IGMP, 

程序 员 可 接受 的 大 多 数 IP 实现 ,都 使 用 抽象 套 接 字 (SOCKET) (与 其 他 协议 也 可 以 
使 用 ) 和 合适 的 API 用 于 大 部 分 操作 。 这 个 接口 称 为 BSD 套 接 字 ,并 最 初 用 于 C 语言 。 


Text B 云 计算 


1. 什么 是 云 计 算 

云 计算 是 一 种 资源 交付 和 应 用 模型 ;这 意味 着 通过 网 络 获取 资源 (如 硬件 .软件 ) 。 
提供 资源 的 网 络 被 称 为 “ 云 "。“ 云 "人 硬件 资源 似乎 可 伸缩 无 限 ,并 且 无 论 何 时 都 可 使 用 。 

云 计算 既 指 通过 互联 网 提供 服务 的 应 用 程序 ,也 包括 数据 中 心 提供 这 些 服务 的 硬件 
和 系统 软件 。 服 务 本 号 一 直 称 为 软件 即 服 务 ( SaaS) ,所 以 我 们 用 这 个 词 。 数 据 中 心 硬 件 
和 软件 ,我 们 称 之 为 云 。 

2. 新 的 应 用 机 遇 

(1) 移动 交互 式 应 用 程序 。Tim O’ Reilly 认为 “未 来 属于 能 实时 做 出 啊 应 的 信息 服 
务 ,无 论 是 它们 的 用 户 提 供 , 或 是 非 人 传感器 提供 。” 这 样 的 服务 将 吸引 到 云 ,不 仅 是 因为 
它们 必须 具有 高 可 用 性 ,而 且 还 因为 这 些 服务 通常 依赖 于 海量 的 数据 集 , 适 宜 在 大 型 数据 
中 心 最 方便 地 承载 。 这 是 特别 的 服务 情景 ,组 合 两 个 或 多 个 数据 源 或 其 他 服务 ,如 混 聚 应 
用 (mash-ups) 。 虽 然 不 是 所 有 的 移动 设备 都 能 够 有 100% 的 时 间 享 受 连接 云 计 算 ,但 在 
特定 的 应 用 领域 已 经 成 功 解决 断 开 操作 存在 的 挑战 ,所 以 我 们 不 认为 这 是 一 个 出 现 移动 
应 用 的 明显 障碍 。 

(2) 并 行 批 处 理 。 到 目前 为 止 我 们 已 经 关注 使 用 云 计 算 的 交互 SaaS, 云 计算 提供 了 
批量 处 理 和 分 析 TB 级 数据 的 独特 机 会 ,并 可 能 花费 几 个 小 时 才能 完成 这 样 的 工作 。 如 
果 应 用 数据 有 足够 的 并 行 性 ,用 户 就 可 以 利用 云 计算 新 的 “成 本 相关 性 "优势 : 在 很 短 的 
时 间 内 使 用 数 百 台 计 算 机 的 成 本 与 使 用 几 台 计算 机 很 长 一 段 时 间 相 当 。 例 如 《华盛顿 
邮 报 》 高 级 工程 师 彼 得 - 哈 金 斯 利用 200 个 EC2 实例 (1407 服务 器 小 时 ) 将 17 481 页 的 
希拉 里 .克林顿 旅行 证 件 转换 为 更 友好 的 形式 ,以 便 在 WWW 发 布 后 的 9 小 时 内 在 
WWW 上 使 用 。 像 Google 的 map reduce 及 其 开源 对 应 的 Hadoop 这 样 的 编程 抽象 允许 
程序 员 表 达 这 些 任务 ,同时 隐藏 了 在 数 百 台 云 计算 服务 器 上 编排 并 行 执行 的 操作 复杂 性 。 
事实 上 ,“ 云 时 代 ” 追 求 在 这 个 领域 的 商业 机 会 。 同 样 , 使 用 Gray 的 洞察 力 , 成 本 /效益 分 
析 必 须 权 衡 大 数据 集 移动 到 云 ,能 够 加 速 数 据 分 析 , 从 中 获得 潜在 收益 。 当 回 到 经 济 模型 
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后 ,我 们 推测 ,亚马逊 提供 大 型 公共 数据 集 免 费 人 驻 的 部 分 动机 可 能 会 减轻 这 种 成 本 分 析 
因素 ,从 而 吸引 用 户 购 买 数据 处 理 所 需 的 云 计算 周期 。 

(3) 分 析 业 的 兴起 。 批 量 处 理 的 计算 密集 型 特例 是 业务 分 析 。 大 型 数据 库 行 业 最 初 
以 事务 处 理 为 主 ,这 种 需求 正在 逐渐 趋 于 平稳 。 越 来 越 多 的 计算 资源 ,现在 用 来 理解 客 
p .供应 链 购买 习惯 .排名 等 。 因 此 ,虽然 网 上 交易 量 继续 缓慢 增长 ,但 是 决策 支持 正在 
迅速 增长 ,资源 的 移动 倾 回 是 从 交易 到 商业 分 析 的 数据 库 处 理 。 

(4) 计算 密集 型 的 果 面 应 用 程序 扩展 。 数 学 的 最 新 版 本 软件 包 MATLAB 和 
Mathematica 都 能 够 使 用 云 计 算 执 行 费 时 的 计算 。 其 他 吕 面 应 用 程序 同样 可 能 从 无 缝 扩 
展 到 云 中 受益 。 同 样 ,一 个 合理 的 测试 结果 要 对 比 在 云 中 的 计算 加 上 移动 数据 进出 云 的 
成 本 , 减 去 使 用 云 计算 节省 时 间 的 成 本 。 符 号 数学 涉及 单位 计算 量 巨大 ,使 其 成 为 值得 研 
究 的 一 个 领域 。 一 个 有 趣 的 替代 模型 可 能 是 数据 保留 在 云 中 ,并 依靠 具有 足够 的 市 宽 , 让 
其 适当 可 视 化 ,返回 给 人 类 用 户 图 形 化 用 户 界 面 。 脱 机 图 像 泻 染 或 3D 动画 可 能 是 一 个 
类 似 的 例子 : 给 出 一 个 三 维 场 景 中 的 对 象 与 所 述 照 明光 源 特性 的 紧凑 描绘 , 泻 染 图 像 是 
计算 字 节 比率 很 高 的 令 人 为 难 的 并 行 计 算 任务 。 

(5)“ 地 面 上 ”的 应 用 。 某 些 应 用 不 能 适应 云 的 弹性 和 并 行 性 ,可 能 受挫 于 数据 移动 
成 本 受制 于 进入 和 离开 云 必需 的 延迟 。 例 如 ,虽然 进行 长 期 财务 决策 相关 的 分 析 适 用 于 
BIE ,但 买卖 股票 需要 微 秒 精度 则 不 运用。 下 到 海量 数据 传输 的 成 本 (以 及 可 能 的 延 
DS ) 减 少 ( 见 第 7 节 ) ,这 些 应 用 程序 可 能 是 明显 不 适合 云 计算 的 代表 。 

i. 云 计 算 经 济 学 

长 期 看 ,决定 是 否 在 云 托管 服务 是 有 道理 的 ,我 们 认为 ,使 用 云 计算 颗 粒度 经 济 模型 
做 出 权衡 决策 更 加 流畅 ,尤其 是 通过 云 提供 的 弹性 服务 转移 风险 。 

同时 ,人 硬件 资源 的 成 本 不 断 下 降 , 它 们 以 变化 的 速率 发 生 。 例 如 ,计算 和 存储 成 本 比 
WAN 成 本 下 降 更 快 。 云 计算 可 以 跟 踊 这些 变化 ,将 它们 更 有 效 地 回馈 到 更 多 的 客户 ,将 
比 建 造 他 们 自己 的 数据 中 心 花 费 更 符合 实际 使 用 资源 的 支出 。 

在 决定 是 否 将 现 有 服务 转 回 云 计 算 时 ,必须 仔细 考虑 预期 的 平均 资源 使 用 和 峰值 资 
源 使 用 情况 ,特别 是 在 应 用 具有 对 资源 需求 高 可 变性 情况 下 ;必须 考虑 购买 设备 的 实际 使 
用 情况 ;以 及 在 不 同 云 环 境 下 的 运行 操作 成 本 。 

ii. 关于 明天 的 云 

长 期 以 来 ,梦想 中 的 计算 作为 一 种 实用 工具 的 愿景 终于 出 现 了 。 通 过 互联 网 这 种 实 
用 工具 的 可 塑性 ,直接 回 客 户 提供 与 业务 需求 相 匹 配 的 服务 ,因为 工作 负载 的 增长 ( 和 收 
缩 ) 速 度 可 能 远 远 快 于 20 年 前 。 过 去 将 业务 发 展 到 数 百 万 客户 需要 数 年 时 间 , 现 在 可 能 
几 个 月 内 就 能 实现 。 

有 人 质疑 公司 是 否 习 惯 了 高 利润 的 企业 ,如 搜索 引擎 和 传统 的 套装 软件 广告 收入 ,可 
以 在 云 计 算 苑 争 。 站 和 完 , 这 个 问题 假定 云 计 算是 一 种 基于 其 低 成 本 小 利润 的 业务 。 鉴 于 
中 型 数据 中 心 的 典型 利用 率 , 规 模 经 济 的 潜在 因子 5:7, 并 在 云 计 算数 据 中 心 的 地 点 选择 
上 进一步 节省 ,提供 给 云 用 户 显 然 成 本 低 , 云 服务 提供 商 仍然 可 能 是 非常 有 利 可 图 的 。 其 
次 ,这 些 公 司 可 能 在 他 们 的 主线 业务 的 基础 设施 中 已 经 拥有 数据 中 心 、 网络 和 软件 。 因 
此 , 云 计 算 模式 代表 再 付出 一 点 额外 的 费用 获得 更 多 收入 的 机 会 。 
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Unit 8. 数据 结构 
Text A Java 语言 的 数据 结构 和 算法 


一 旦 学 会 了 编程 ,就 会 遇 到 现实 世界 中 的 问题 ,解决 这 些 问 题 需 要 的 不 仅 是 一 门 编程 
语言 。Java 语言 的 数据 结构 与 算法 就 是 一 个 逐渐 沉浸 其 中 的 最 实用 的 方式 , 它 可 使 数据 
做 你 想 让 它 做 的 事情 。 

1. 数据 结构 概貌 

看 数据 结构 的 男 一 种 角度 是 专注 于 它 的 长 处 和 短处 。 本 节 将 提供 一 个 概貌 ,如 
X 8-1 所 示 ,我 们 将 讨论 主要 的 数据 存储 结构 。 

2. 算法 概貌 

我 们 讨论 的 很 多 算法 都 直接 适用 于 特定 的 数据 结构 。 对 于 大 多 数 的 数据 结构 ,我 们 
需要 知道 

(1) 插入 新 的 数据 项 。 

(2) 搜索 指定 的 项 。 

(3) 删除 指定 的 项 。 

可 能 还 需要 知道 如 何 通过 迭代 遍历 数据 结构 中 的 所 有 项 目 , 因 此 访问 每 一 项 ,以 显示 
它 或 在 其 上 执行 一 些 其 他 操作 。 其 中 一 个 重要 的 算法 类 称 为 排序 。 对 数据 进行 排序 有 很 
多 种 方法 ,递归 的 概念 在 设计 某 些 算法 时 很 重要 。 

3. 面向 对 象 编程 

因为 过 程 语言 如 C、Pascal Al BASIC 不 能 处 理 大 型 和 复杂 的 程序 ,因此 要 发 明 面 向 对 
象 编程 语言 。 为 什么 这 样 ? 

这 些 问 题 与 程序 的 整体 组 织 有 关 。 过 程 编 程 通过 将 代码 划分 为 一 个 个 图 数 (一 些 语 
言 称 为 过 程 或 子 程序 ) 组 成 。 一 组 水 数 可 以 形成 较 大 的 单位 称 为 模块 或 文件 。 基 于 哺 数 
组 成 的 代码 存在 的 一 个 问题 是 以 牺牲 数据 为 代价 来 关注 图 数 。 对 数据 ,没有 很 多 的 选择 。 
简单 地 说 ,数据 对 本 地 的 一 个 特定 的 函数 可 访问 ,或 者 它 对 所 有 哺 数 全 局 可 访问 。 没 有 办 
法 (至 少 没 有 灵活 的 方式 ) 指 定 某 些 函数 可 以 访问 一 个 变量 ,而 其 他 函数 不 能 。 当 几 个 函 
数 需 要 访问 相同 的 数据 时 将 引起 问题 。 要 提供 给 一 个 以 上 的 函数 访问 ,这 样 的 变量 必须 
是 全 局 性 的 ,但 全 局 数据 可 能 被 程序 中 的 任何 函数 无 意 访问 到 。 这 导致 频繁 的 编程 错误 。 
所 需要 做 的 是 微调 数据 的 访问 方式 ,允许 变量 对 需要 访问 它 的 图 数 有 效 ,但 对 其 他 哺 数 隐 
藏 起 来 。 


4. 简 而 言 之 
对 象 概念 的 想法 产生 于 编程 社区 ,作为 解决 过 程 语言 问 题 的 方案 。 
(1) HA 


对 象 是 新 的 实体 。 对 象 可 以 同时 解决 几 个 问题 。 不 仅 一 个 编程 对 象 更 精确 地 与 真实 
世界 中 的 对 象 相对 应 ,而 且 它 也 解决 了 过 程 模 型 中 的 全 局 数据 所 产生 的 问题 。 
(2) 类 
你 可 能 认为 一 个 “对象 " 的 想法 足以 引起 编程 革命 ,但 还 有 更 多 的 新 思想 。 早 期 ,人 
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们 认识 到 ,你 可 能 想 使 用 相同 类 型 的 多 个 对 象 。 也 许 你 正在 为 整个 公寓 编写 一 炉 温 控制 
程序 ,例如 ,你 需要 在 你 的 程序 中 添加 几 十 个 温 控 对 象 。 因 此 ,类 的 想法 诞生 了 。 


Text B 两 类 重要 数据 结构 


这 一 部 分 将 简要 介绍 两 个 重要 的 数据 结构 : 链表 和 哈 硕 表 ,这 是 有 效 搜索 或 存储 数 
据 的 结构 。 

1. 链表 

我 们 看 到 ,作为 数据 存储 结构 ,数组 有 一 定 的 缺点 。 对 无 序 排列 的 数组 ,搜索 是 绥 慢 
的 ,而 在 有 序数 组 中 ,插入 是 缓慢 的 。 在 这 两 种 情况 下 进行 数组 删除 操作 速度 很 慢 。 男 
外 ,数组 创建 之 后 ,大 小 不 能 变化 。 在 这 一 部 分 ,我 们 将 看 看 能 解决 一 些 问 题 的 数据 存储 
结构 : 链表 。 

链表 可 能 是 数组 之 后 的 第 二 个 最 常用 的 通用 存储 结构 。 链 表 是 一 种 多 功能 的 结构 ， 
适用 于 多 种 通用 数据 库 。 它 也 可 以 取代 数组 ,作为 其 他 存储 结构 ,如 堆栈 和 队列 的 基础 。 
事实 上 ,在 很 多 情况 下 可 以 使 用 一 个 链表 代替 数组 (除非 你 需要 使 用 一 个 索引 频繁 且 随 
机 存 取 个 别 元 素 ) 。 链 表 并 不 能 解决 所 有 的 数据 存储 问题 ,但 它们 提供 令 人 惊讶 的 功能 
和 概念 , 比 其 他 一 些 流行 的 结构 (如 树 结 构 ) 简单 。 因 为 我 们 专注 发 现 它 们 的 长 处 和 短 
处 。 在 这 一 节 中 我 们 参考 两 个 非常 有 用 的 数据 结构 。 

2. 链接 

在 一 个 链表 中 ,各 数据 项 舱 入 在 一 个 链接 。 链 接 是 一 个 类 似 链条 的 对 象 。 因 为 链接 
与 列表 链接 有 很 多 类 似 性 ,所 以 使 用 一 个 单独 的 类 从 链表 本 号 区 分 出 来 是 有 道理 的 。 每 
个 链接 对 象 都 包含 一 个 引用 (通常 称 为 下 一 个 next) ,通常 指 癌 列表 中 的 下 一 链接 对 象 。 
包含 列表 的 字段 本 身 参 考 第 一 链 路 。 下 面 是 一 个 链接 类 定义 的 一 部 分 , 它 包 含 一 些 数 气 ， 
并 指向 下 一 个 链接 。 


class Link 
{ 

public int iData; // 数 据 

ablic double data; /人 数据 

public Link next; // 指 癌 下 一 个 链接 


} 

这 种 类 的 定义 有 时 被 称 为 自 引 用 ,因为 它 包 含 了 一 个 它 自 己 的 类 定义 。 

3. MBAR 

哈 希 表 是 一 个 数据 结构 , 它 提供 了 非常 快速 的 插入 和 搜索 。 当 第 一 次 听 到 哈 希 表 , 听 
起 来 几乎 是 好 得 令 人 难以 置信 。 不 管 有 多 少数 据 项 ,插入 和 搜索 (有 时 删除 ) 都 可 以 接近 
固定 的 时 间 : OC) 的 时 间 级 。 实 际 上 ,这 仅仅 是 几 个 机 需 指令 。 对 于 一 个 哈 硕 表 ,相对 
人 类 用 户 来 说 ,基本 上 是 瞬时 。 它 是 如 此 之 快 ,计算 机 程序 通常 使 用 哈 希 表 , 当 它们 需要 
在 不 到 一 秒 的 时 间 查 找 成 千 上 万 的 项 目 时 (如 拼写 检查 )。 哈 希 表 比 树 结构 明显 快 。 不 
仅 速度 快 , 哈 硕 表 也 较 易 编程 。 哈 硕 表 确实 有 一 些 缺 点 。 它 们 基于 数组 ,而 数组 一 旦 创 
建 ,扩大 就 很 难 。 对 于 某 些 类 型 的 哈 希 表 , 当 表 变 得 过 满 时 ,性 能 可 能 会 降低 ,其 至 成 为 灾 
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难 , 因 此 ,程序 员 需 要 对 具体 的 项 目 将 存储 多 少数 据 进 行 一 个 相当 精确 的 估算 (或 为 周期 
性 将 数据 传输 到 一 个 更 大 的 哈 希 表 , 一 个 耗 时 的 工序 作 准 备 ) 。 

为 外 ,没有 便捷 的 方式 可 对 哈 希 表 实 现任 何 有 序 的 访问 ( 如 从 最 小 到 最 大 ) 。 如 有 果 需 
要 这 个 功能 ,就 要 查看 别 的 。 但 是 ,如 果 不 需 要 顺序 访问 各 项 内 容 , 并 且 你 可 以 预测 你 的 
数据 库 大 小 , 哈 希 表 的 速度 和 便捷 就 是 无 与 伦比 的 。 


Unit 9 ”微软 开发 者 网 络 
Text A 什么 是 MSDN 


微软 开发 者 网 络 ( MSDN ) 是 微软 的 一 部 分 ,负责 管理 协调 该 公司 开发 人 员 和 测试 人 
员 间 的 关系 : 关注 操作 系统 (OS ) 的 人 硬件 开发 人 员 ,在 不 同 操作 系统 平台 的 开发 人 员 , 充 
分 利用 API 和 微软 许多 应 用 程序 的 脚本 语言 的 开发 人 员 。 这 种 关系 管理 分 布 在 不 同 的 
场合 : 网 站 nidi AT AN AI ,行业 媒体 、 博 客 和 DVD 发 行 。 关 系 的 生命 周期 从 遗留 
系统 文 持 到 宣传 中 的 潜在 产品 。 

1. 发 展 史 

该 服务 始 于 1992 年 ,但 最 初 仅 在 微软 开发 者 网 络 光 盘 (CD-ROM ) 中 可 用 。1993 年 
增加 了 二 级 预订 ,包括 MAPI ODBC TAPI 和 VFW 的 软件 开发 工具 (CSDK) 2004 年 11 
月 ,MSDN2 作为 Visual Studio 2005API 信息 来 源 打造 ,与 正在 更 新 网 站 的 代码 具有 显著 
的 差异 ,更 符合 Web 标准 ,从 而 可 使 用 期 待 已 久 的 支持 API 的 改进 浏览 器 替 代 正 浏览 
fit. 2008 年 , 原 MSDN 群 退 休 , MSDN2 成 为 msdn. microsoft. com, 

1992 年 2) - [X AR ARLE MSDN 开发 者 新 闻 ( 一 个 纸 质 出 版 物 ) 开始 使 用 假名 “Dr. 
GUI” 写 专栏 。 专 栏 回 答 MSDN 订户 提出 的 问题 。GUI 博士 的 漫画 是 基于 Bob 的 照片 。 
当 他 离开 MSDN 团队 后 ,丹尼斯 . 克 雷 恩 接 手 GUI 博士 的 角色 并 加 入 医疗 幽默 到 栏目 
中 。 在 他 离开 后 ,GUI 博士 成 为 开发 者 技术 工程 师 原 团 队 ( 最 明显 的 是 保罗 . 约翰) 提供 
高 深 的 技术 文章 到 数据 库 的 复合 代表 。 总 之 ,这 是 一 个 好 地 方 ,全 方位 存放 MSDN 任务 。 
Ken Lassesen Æ P AY JRA BE ( Panda) 发 布 MSDN 在 互联 网 上 ,并 以 HTML 格式 代替 早期 
的 多 媒体 浏览 硕 引 擎 。 戴 尔 罗 杰 和 森 、 奈 杰 尔 … Wat AeA A CLUTs 在 MSDN 团队 时 出 
版 已 发 布 的 MS 出 版 社 的 书籍 。 截 至 2010 年 8 月 ,微软 很 少 记得 那 位 博士 了 。 

2. 信息 服务 

微软 为 软件 开发 人 员 提 供 了 一 个 信息 服务 。 它 的 主要 焦点 是 微软 的 . NET 平台 ,但 
它 也 拥有 如 编程 实践 和 设计 模式 等 领域 的 文 草 。 网 上 有 许多 免费 资源 ,有 的 则 是 通过 邮 
件 订阅 。 

根据 订阅 级 别 , 用 户 可 能 会 收 到 微软 的 操作 系统 或 其 他 Microsoft 产品 (如 Microsoft 
Office 应 用 程序 、Visual Studio 等 ) 的 早期 版 本 。 

大 学 和 高 中 可 以 报名 参加 MSDN 学 术 联 盟 计 划 , 它 为 他 们 的 计算 机 科学 与 工程 专业 
的 学 生 ( 可 能 还 有 其 他 专业 的 学 生 或 教师 ) 提供 访问 一 些微 软 的 开发 软件 。 一 个 
MSDNAA 账户 不 是 一 个 MSDN 账户 ,并 且 不 能 用 来 访问 MSDN 网 站 或 者 其 订户 的 下 载 
区 域 。 
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3. 软件 订阅 

MSDN 以 往 提供 订阅 包 , 从 而 开发 人 员 可 以 访问 和 许可 使 用 曾经 发 布 的 几乎 所 有 的 
微软 软件 。 订 阅 以 年 论 ,每 年 每 份 花 费 高 达 10 939 美元 ,因为 它 是 从 里 到 外 地 提供 。 订 
阅 持 有 人 ( 除 最 低 库 访 问 级 别 ) 每 隔 几 个 星期 或 数 月 将 通过 DVD 或 下 载 接收 到 新 的 
Microsoft 软件 。 软 件 一 般 都 在 带 有 特意 标明 MSDN 的 光盘 上 ,但 包含 了 与 零售 或 批量 授 
权 相 同 的 软件 ,因为 它 是 向 公众 发 布 。 

虽然 在 大 多 数 情况 下 ,软件 本 号 的 功能 与 完整 产品 的 完全 一 样 ,但 在 MSDN 最 终 用 
户 许 可 协议 禁止 在 企业 生产 环境 中 使 用 该 软件 。 这 是 一 个 法 律 上 的 限制 ,而 不 是 一 个 技 
术 问 题 。 作 为 一 个 例子 ,MSDN 定期 包括 最 新 的 Windows 操作 系统 (如 Windows Vista 和 
Windows 7) .服务 器 软件 (如 SQL Server 2008) 开发 工具 (如 Visual Studio) .应 用 程序 
(如 Microsoft Office 和 MapPoint) 。 对 于 需要 产品 密 钥 的 软件 ,微软 网 站 根据 需求 生成 。 
这 种 包 提 供 了 单个 计算 机 爱好 者 可 访问 几乎 所 有 微软 提供 的 产品 。 然 而 ,办 公 室 的 PC 
和 服务 硕 上 运行 订阅 的 MSDN 软件 如 果 运 行 在 这 些 机 各 上 没有 适当 的 非 MSDN 许可 
证 ,各 被 抓 到 ,与 通过 盗版 获得 的 软件 ,软件 许可 审计 处 理 结果 没有 什么 不 同 。 


Text B 认识 MSDN 


MSDN 的 主要 网 站 在 msdn. microsoft. com, 它 是 为 开发 者 社区 提供 人 信息、 文档、 由 
Microsoft 和 广大 社区 网 民 撰 写 .讨论 的 网 站 。 最 近 对 论坛 .博客 . 库 的 注释 和 社交 书签 等 
应 用 程序 的 强调 和 整合 正在 改变 MSDN 网 站 的 性 质 , 从 单 回信 息 服 务 转变 为 Microsoft 
和 开发 人 员 社 区 之 间 的 公开 对 话 。 在 其 主 站 和 大 部 分 所 列 的 应 用 提供 56 种 以 上 的 语言 
内 容 。 

1. System. ComponentModel 命名 空间 

System. ComponentModel 命名 空间 提供 用 于 实现 组 件 和 控件 的 运行 时 和 设计 时 行为 
的 类 。 本 命名 空间 包括 属性 和 类 型 转换 带 实 现 .数据 源 绑 定 和 授权 组 件 的 基 类 和 接口 。 

此 命名 空间 的 类 分 为 以 下 5 类 。 

e 核心 组 件 类 , 见 组 件 Component IComponent , Container 和 IContainer 类 。 

e 组 件 许 可 , 见 License, LicenseManager , LicenseProvider 和 LicenseProviderAttribute 
类 。 

e 属性 , 见 属性 类 。 

e 描述 符 和 持久 性 , 见 TypeDescriptor ,EventDescriptor 和 PropertyDescriptor 类 , 

e KAI EEr, IL TypeConverter 类 。 

2. AsyncCompletedEventArgs 类 

它 为 MethodNameCompleted 事件 提供 数据 。 

如 果 你 使 用 的 是 基于 事件 的 一 个 同步 模式 ,实现 的 类 将 提供 MethodNameCompleted 
事件 。 如 果 你 添加 System. ComponentModel. AsyncCompletedEventHandler 委托 处 理事 件 
的 一 个 实例 ,将 收 到 有 关 同 步 操 作 相 应 事件 处 理 程序 方法 的 参数 AsyncCompletedEventArgs 
结果 的 信息 。 

客户 端 应 用 程序 的 事件 处 理 程序 委托 可 以 检查 取消 属性 ,以 确定 在 异步 任务 是 否 被 

: 259 - 


取消 。 

客户 端 应 用 程序 的 事件 处 理 程序 委托 可 以 检查 Error 属性 ,以 确定 在 异步 任务 的 执 
行 过 程 中 异常 是 否 发 生 。 

如 果 类 文 持 多 个 异步 方法 或 多 次 调用 同一 个 异步 方法 ,你 可 以 决定 哪些 任务 通过 检 
ft UserState 属性 的 值 触发 MethodNameCompleted 事件 。 你 的 代码 将 需要 跟踪 这 些 令 牌 
( 称 为 任务 的 ID) ,在 它们 的 相应 异步 任务 开始 和 完成 时 。 

随后 的 基于 事件 的 异步 模式 的 类 可 以 引发 事件 ,提醒 客户 问 有 关 甚 挂 异步 操作 的 状态 。 
如 果 这 个 类 产生 了 一 个 MethodNameCompleted 事件 ,可 以 使 用 AsyncCompletedEventArgs 
告诉 客户 有 关 异 步 操 作 的 结果 。 

你 可 能 希望 一 个 异步 操作 的 结果 问 客 户 传 递 比 AsyncCompletedEventArgs 容纳 更 多 
的 信息 。 在 这 种 情况 下 ,你 可 以 从 AsyncCompletedEventArgs 类 派生 日 己 的 类 ,并 提供 额 
外 的 私有 实例 变量 和 相应 的 只 读 公 共 属 性 。 返 回 属性 值 前 ,调用 RaiseExceptionIfNecessary 
方法 ,即使 操作 被 取消 或 发 生 错误 。 

3. IComponent 接口 

IComponent 接口 提供 了 所 有 组 件 所 需 的 功能 。 

Component 是 IComponent 的 默认 实现 ,并 作为 公共 语言 运行 库 的 所 有 组 件 的 基 类 。 

可 以 在 容 需 中 包含 部 件 。 在 这 种 情况 下 ,容纳 指 逻辑 容纳 ,而 不 是 视觉 容纳 。 你 可 以 
在 各 种 情景 下 使 用 组 件 和 容 需 ,包括 可 视 的 和 非 可 视 的 。 

System. Windows. Forms. Control 从 Component 组 件 继承 下 来 ,是 IComponent 的 默认 
实现 。 

一 个 组 件 与 它 的 容 表 相互 作用 主要 通过 一 个 容 需 提供 的 ISite ,这 是 特定 容 硕 的 每 个 
组 件 信息 构成 的 信息 库 。 

要 成 为 一 个 组 件 , 类 必须 实现 IComponent 接口 ,并 提供 一 个 无 需 参 数 或 单个 参数 
IContainer 类 型 的 基本 构造 晒 数 。 有 关 IComponent 实现 的 更 多 信息 ,请 参阅 使 用 组 件 
编程 。 


Unit 10 编译 原理 


Text A 代码 优化 的 科学 


术语 “优化 "在 编译 带 设 计 中 指 的 是 一 个 编译 天 试图 产生 比 直 接 代码 更 高 效 的 代码 。 
因此 ， 优 化 "一 词 用 词 不 当 , 因 为 没有 办 法 保证 编译 融 产生 的 代码 与 任何 其 他 代码 执行 
相同 的 任务 一 样 快 或 更 快 。 

现在 ,代码 优化 的 编译 名 执行 已 经 变 得 更 重要 .更 复式 了 了 。 更 复杂 是 因为 处 理 硕 以 构 
变 得 越 来 越 复杂 ,产生 更 多 的 机 会 改善 代码 执行 方式 。 更 重要 是 因为 大 规模 并 行 的 计算 
机 需要 大 量 的 优化 ,或 它们 的 性 能 取决 于 执行 顺序 。 随 春 多 核 机 货 ( 计 算 机 必 片 上 有 多 
^ kb SB gs ) 的 出 现 , 所 有 的 编 详 禹 将 不 得 不 面 对 充 分 利用 多 处 理 表 机 表 优 势 的 问题 。 

这 是 很 难 ,不 是 不 可 能 的 ,但 要 建立 一 个 强大 的 编译 需 " 黑客" 。 因 此 ,围绕 优化 代码 
的 问题 ,扩展 的 和 有 用 的 理论 已 被 建立 起 来 。 采 用 严格 的 数学 的 基础 ,让 我 们 表明 ,优化 
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是 正确 的 ,对 所 有 可 能 的 输入 它 产生 了 理想 的 效果 。 我 们 将 看 到 ,从 第 9 章 , 如 果 编 译 器 
要 生成 优化 好 的 代码 ,那么 图 .矩阵 和 线性 程序 等 模型 是 多 么 重要 。 

另 一 方面 , 仅 靠 纯 理论 是 不 够 的 。 就 像 许多 现实 世界 的 问题 ,没有 完美 的 答案 。 事 实 
上 ,大 多 数 的 我 们 在 编译 器 优化 提出 的 问题 是 不 可 判定 的 。 其 中 ,在 编译 器 设计 中 一 个 最 
重要 的 技能 是 确定 要 解决 真正 问题 的 能 力 。 我 们 从 对 程序 的 行为 有 很 好 的 理解 和 人手 , 通 
过 实验 和 评估 验证 我 们 的 直觉 。 编 译 需 优化 必须 满足 以 下 设计 目标 。 

优化 必须 正确 ,也 就 是 说 ,保持 已 编译 的 程序 的 含义 。 

优化 必须 改善 许多 程序 的 性 能 。 

编译 时 间 必 须 合 理 。 

所 需 的 工程 工作 必须 是 可 控 的 。 

无 论 如 何 强调 正确 性 ,都 不 过 分 。 编 译 需 产生 快速 的 代码 ,如 果 生 成 的 代码 不 一 定 正 
确 , 就 是 没有 意义 的 ! 优化 的 编译 器 如 此 难以 保证 正确 ,我 们 敢 说 ,没有 优化 的 编译 器 是 
完全 没有 错误 的 ! 因此 ,编写 编译 需 最 重要 的 目标 是 , 它 是 正确 的 。 

第 二 个 目标 是 ,编译 器 必须 有 效 地 改善 多 输入 程序 的 性 能 。 通 常 表现 为 程序 执行 的 
速度 。 尤 其 是 在 舱 入 式 应 用 中 ,我 们 不 妨 尽 量 减少 生成 代码 的 大 小 。 而 在 移动 设备 情况 
下 ,也 期 望 是 ,代码 减少 功 耗 。 通 常 ,同一 优化 既 加 快 了 执行 时 间 ,也 降低 了 功 耗 。 除 了 性 
能 ,有 关 错 误 报告 和 调试 的 方面 ,可 用 性 也 很 重要 。 

第 三 ,我 们 需要 保证 编译 时 间 短 ,支持 快速 开发 和 调试 周期 。 因 机 需 变 得 更 快 ,此 要 
求 已 变 得 更 容易 满足 。 通 常 ,一 个 程序 首先 必须 经 过 程序 优化 进行 开发 和 调试 。 不 仅 是 
编译 时 间 减 少 了 ,更 重要 的 是 ,未 优化 方案 比较 容易 调试 ,因为 由 编译 器 引入 的 优化 经 常 
混 消 源 代 码 和 目标 代码 之 间 的 关系 。 打 开 的 编译 器 优化 选项 有 时 暴露 源 程序 中 的 新 问 
题 ;因此 ,必须 再 次 对 优化 的 代码 进行 测试 。 需 要 额外 的 测试 有 时 阻止 在 应 用 中 使 用 优 
化 ,尤其 是 如 果 它 们 的 性 能 并 不 重要 时 。 

最 后 ,一 个 编译 右 是 一 个 复杂 的 系统 ;我 们 必须 保持 系统 简单 ,以 确保 编译 右 的 工程 
和 维护 成 本 是 可 控 的 。 还 有 ,我 们 可 以 实现 程序 的 优化 无 限 化 , 它 需 要 付出 不 平凡 的 努力 
创建 一 个 正确 的 和 有 效 的 优化 。 我 们 必须 优先 考虑 的 优化 , 仅 是 针对 在 实践 中 遇 到 的 源 
程序 可 取得 最 大 效益 的 工作 。 

因此 ,在 研究 编译 器 时 ,我 们 不 仅 学 习 如 何 构建 一 个 编译 器 ,同时 也 学 习 解 决 复杂 和 
开放 性 问题 的 一 般 方法 。 编 译 器 开发 使 用 的 方法 既 包 括 理论 ,又 包括 实验 。 我 们 通常 基 
于 直觉 认可 的 什么 是 重要 问题 开始 进行 规划 。 


Text B 计算 机 结构 优化 


计算 机 体系 结构 的 快速 发 展 导 致 新 的 编译 船 技 术 无 限 的 需求 。 几 乎 所 有 的 高 性 能 系 
统 都 采取 同样 的 两 种 基本 技术 优势 : 并 行 性 和 存储 表层 次 结构 。 并 行 性 可 以 在 多 个 级 别 
中 找到 : 在 指令 级 ,其 中 多 个 操作 同时 执行 ;在 处 理 需 级 ,其 中 同一 应 用 程序 的 不 同 线程 
在 不 同 的 处 理 硕 上 运行 。 内 存 层 次 结构 的 基本 限制 ,我 们 可 以 建立 非常 快 的 存储 或 量 非 
常 大 的 存储 ,而 不 是 存储 既 快速 , 量 也 大 的 啊 应 。 

所 有 的 现代 微 处 理 融 都 开发 指令 级 并 行 性 。 然 而 ,这 种 并 行 性 可 以 癌 程 序 员 隐 藏 。 
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编写 程序 时 ,总 认为 所 有 指令 是 串 行 执行 的 ;硬件 动态 检查 顺序 指令 流 中 的 依赖 关系 , 尽 
可 能 发 布 它 们 并 行 执行 。 在 一 些 情 况 下 ,机 器 包括 硬件 调度 器 ,可 以 改变 它 的 指令 排序 ， 
也 可 以 增加 并 行 性 。 无 论 是 便 件 重 新 排序 ,或 没有 ,编译 需 都 可 以 对 指令 重新 排序 ,使 指 
令 级 并 行 更 有 效 。 

指令 级 并 行 也 可 以 明确 地 出 现在 指令 集 上 。VLIW( 超 长 指令 字 ) 机 各 具有 可 以 并 行 
发 出 多 个 操作 的 指令 。 英 特 尔 IA64 是 这 种 架构 的 著名 例子 。 所 有 的 高 性 能 通用 微 处 理 
需 也 包括 可 以 在 同一 时 间 上 操作 数据 矢量 的 指令 。 这 样 的 编译 需 技 术 已 被 开发 ,从 顺序 
程序 自动 地 产生 代码 用 于 这 样 的 机 需 。 

多 处 理 器 已 很 普遍 。 即 使 个 人 计算 机 ,也 通常 具有 多 个 处 理 器 。 程 序 员 可 以 为 多 处 
理 需 编写 多 线程 代码 ,或 者 通过 从 传统 的 顺序 程序 编译 融和 目 动 生成 并 行 代码 。 这 样 的 编 
译 器 对 程序 员 隐 藏 了 许多 细节 ,在 程序 发 现 并 行 性 , 横 跨 不 同 机 型 的 分 发 计算 ,并 尽量 减 
少 处 理 帮 之 间 的 同步 和 通信 。 许 多 科学 计算 和 工程 应 用 都 是 计算 密集 的 ,可 以 从 并 行 处 
理 大 大 受益 。 并 行 化 技术 已 经 发 展 到 目 动 将 串 行 科学 程序 翻译 成 多 处 理 需 的 代码 。 

存储 需 层 次 结构 包含 存储 速度 和 容量 大 小 不 同 水 平 的 几 个 层次 , 带 有 最 接近 处 理 需 
而 速度 最 快 的 ,但 容量 最 小 的 层次 。 平 均 存 储 需 的 存 取 时 间 将 减少 ,如 果 大 部 分 的 访问 是 
由 层次 结构 速度 更 快 的 存储 需 满 足 程序 需要 。 并 行 性 和 存储 需 层次 结构 的 存在 都 可 提高 
机 器 的 潜在 性 能 ,但 它们 必须 有 效 地 通过 编译 器 实现 应 用 程序 的 实时 性 能 。 

所 有 计算 机 都 有 存储 右 层 次 结构 。 人 处理 絮 通 常 含有 小 数目 的 寄存 器、 几 百 上 千 字 节 、 
不 同 水 平 的 几 千 到 兆 字 节 高 速 缓存 、 兆 字 节 到 千 兆 字 节 物理 存储 器 ,以 及 从 吉 字 节 甚 至 更 
多 的 最 终 辅助 存储 。 相 应 地 ,层次 结构 的 相 邻 水 平 之 间 的 访问 速度 不 同 幅 度 可 以 达到 两 
个 或 3 个 数量 级 。 一 个 系统 的 性 能 经 常 不 受 限 于 处 理 右 速度 ,而 是 取决 于 存储 大 子 系统 
的 性 能 。 传 统 编译 需 重 点 优化 处 理 需 的 执行 ,现在 更 强调 放置 在 哪 ,使 得 存储 需 层 级 更 
有 效 。 

有 效 使 用 寄存 需 在 优化 方案 中 可 能 是 一 个 最 重要 的 问题 。 不 像 寄 存 硕 可 以 在 软件 进 
行 显 式 管理 ,高 速 缓存 和 物理 存储 融 隐 藏 在 指令 集 并 由 硬件 管理 。 现 已 发 现 , 在 一 些 情 况 
下 ,通过 硬件 实现 的 高 速 缓存 管理 策略 并 不 有 效 , 尤 其 是 在 科学 代码 具有 大 的 数据 结构 
(典型 的 和 矩阵) 时 。 有 可 能 通过 改变 数据 的 布局 ,或 改变 存 取 数据 的 指令 顺序 ,以 提高 存 
储 需 层次 结构 的 有 效 性 。 我 们 还 可 以 改变 代码 的 布局 ,以 提高 指令 缓存 的 有 效 性 。 


Unit 11 操作 系统 
Text A 操作 系统 概述 


1. 什么 是 操作 系统 
操作 系统 是 软件 ,由 计算 机 上 运行 的 程序 和 数据 组 成 ,主要 管理 计算 机 硬件 并 为 各 种 
应 用 软件 有 效 执行 提供 公共 服务 。 
管理 人 硬件 的 功能 如 输入 、 输 出 和 存储 需 分 配 ,操作 系统 充当 应 用 程序 和 计算 机 便 件 之 
间 的 中 介 ,虽然 应 用 程序 代码 通 第 由 便 件 直接 执行 ,但 会 频 楷 调用 操作 系统 或 被 它 中 断 。 
几乎 在 任何 包含 一 台 计 算 机 的 设备 上 ,都 可 以 找到 操作 系统 ,从 蜂 寅 手机 和 视频 游戏 机 到 
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超级 计算 机 和 Web 服务 器 。 

2. 操作 系统 的 历史 

20 世纪 50 年 代 初 ,一 台 计 算 机 同一 时 间 只 能 执行 一 个 程序 。 每 个 用 户 单独 使 用 计 
算 机 ,并 会 在 预定 的 时 间 通 过 穿孔 纸 卡 片 和 磁带 提供 程序 和 数据 。 程 序 将 加 载 到 该 设备 ， 
机 需 将 一 直 设 置 为 工作 状态 ,直到 程序 完成 或 关 溃 。 程 序 一 般 可 以 调试 ,通过 使 用 前 面 控 
制 板 上 的 切换 开关 和 面板 灯 。 据 说 ,阿兰 . 图 灵 是 早期 的 曼彻斯特 马克 1 号 机 上 的 主人 ， 


以 后 的 机 器 附带 软件 库 ,这 将 链接 到 用 户 的 程序 协助 一 些 操作 ,如 输入 和 输出 ,将 人 
可 读 的 符号 代码 转换 成 计算 机 代码 。 这 是 现代 操作 系统 的 起 源 。 但 是 ,计算 机 在 同一 时 
间 仍 然 运行 单个 作业 。 在 英国 剑桥 大 学 ,在 同一 时 间作 业 队 列 的 磁带 上 挂 着 不 同 颜色 的 
衣服 夹子 ,表明 作业 优先 级 。 

3. 大 型 机 

经 过 20 世纪 50 年 代 , 在 操作 系统 领域 开创 了 许多 主要 功能 ,包括 批量 处 理 .输入 输 
出 中 断 缓冲 多 任务 处 理 . 后 台 、 运 行 时 库 链接 加 载 ,以 及 在 文件 中 记录 排序 程序 。 这 些 
特征 可 作为 应 用 程序 员 的 选项 ,应 用 软件 可 纳入 或 不 纳入 ,而 不 是 所 有 应 用 都 使 用 一 个 独 
立 的 操作 系统 。1959 年 ,作为 IBM 704,709 和 7090 主机 的 综合 工具 的 操作 系统 发 行 了 。 

20 世纪 60 年代 ,IBM 的 OS/360 推出 了 一 个 操作 系统 的 概念 ,涵盖 了 整个 产品 线 , 对 
System/360 取得 成 功 至 关 重 要 。IBM 目前 的 大 型 机 操作 系统 都 是 这 种 原始 系统 的 远亲 后 
代 , 并 且 OS/360 上 的 应 用 程序 仍 可 以 在 现代 机 需 上 运行 。20 世纪 70 年 代 中 期 ,MVS、 
OS/360 的 后 裔 第 一 个 实现 了 使 用 RAM 作为 数据 的 透明 缓存 。 

4. 微电脑 

第 一 代 微 型 计算 机 还 没有 精心 制作 操作 系统 的 能 力 或 需求 ,如 没有 开发 用 于 大 型 机 
和 迷你 机 系统 ,而 是 开发 简约 操作 系统 ,往往 从 ROM 加 载 并 称 为 监视 器 。 一 个 著名 的 、 
早期 的 基于 磁盘 的 操作 系统 是 CP/M, 它 得 到 许多 早期 的 微型 计算 机 支持 ,并 被 MS- 
DOS 高 度 模仿 , 变 得 广 受 欢迎 ,作为 [BM PC 操作 系统 的 选择 (IBM 版 称 为 IBM DOS 或 
PC DOS) ,是 微软 的 成 功 产 品 。20 世纪 80 年 代 ,苹果 电脑 公司 (现在 的 苹果 公司 ) 放 弃 了 
其 广 受 欢迎 的 Apple II 系列 单片机 ,创新 地 将 图 形 用 户 界 面 (GUI) Mac OS 引入 到 苹果 
Macintosh 计算 机 。， 

5. 操作 系统 的 实例 

(1) 微软 Windows 

微软 Windows 是 在 个 人 计算 机 上 最 常用 的 特有 操作 系统 家 族 。 它 是 个 人 计算 机 中 
最 常见 操作 系统 的 系列 ,目前 市 场 占有 率 约 90% 。Windows 系列 中 使 用 的 最 广泛 的 版 本 
je Windows XP, 其 于 2001 年 10 H 25 日 发 布 。 最 新 的 版 本 是 适用 于 个 人 计算 机 的 
Windows 7 和 适用 于 服务 途 的 Windows Server 2008 R2, 

(2) UNIX fil UNIX 类 操作 系统 

A: 汤 普 逊 写 B 代码 ,主要 是 基于 BCPL ,基于 他 在 MULTICS 项 目 经 验 , 他 使 用 它 
编写 UNIX, JH C 语言 代替 B 语言 ,UNIX 发 展 为 大 型 复杂 的 相互 关联 的 操作 系统 家 
族 , 已 影响 到 每 一 个 现代 操作 系统 。UNIX 类 家 族 是 一 组 不 同 的 操作 系统 ,有 几 个 主要 的 
子 类 ,包括 System V .BSD fll GNU/Linux 操作 系统 。 名 称 “UNIX” 是 The Open Group 的 
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商标 ,用 于 与 符合 其 定义 的 任何 操作 系统 使 用 的 许可 证 。“UNIX 类 ”通常 指 类 似 于 原 
UNIX 操作 系统 组 成 的 大 型 集合 。 

(3) Mac OS X 

Mac OS X 是 由 苹果 公司 开发 .营销 和 销售 的 专 有 图 形 操作 系统 系列 产品 ,最 新 的 版 
本 是 所 有 目前 推出 的 Macintosh 计算 机 预先 安装 的 。Mac OS X 的 前 号 是 原来 的 Mac 
OS, A 1984 年 以 来 , 它 是 苹果 机 的 主流 操作 系统 。Mac OS X 是 建立 在 UNIX 操作 系统 
开发 的 技术 ,这 由 Next 公司 开发 始 于 20 世纪 80 年 代 后 期 ,直到 1997 年 初 苹果 公司 购买 
了 该 公司 。 

1999 年 首次 发 布 Mac OS X Ak at 1.0 操作 系统 ,2001 年 3 月 发 布 了 面 回 条 面 版 本 
(Mac OS X 10.0 版 ) ,此 后 ,6 个 不 同 的 Mac OS X “ZP” Al“ ARS He” RAGA AG, Bz 
近 一 次 是 Mac OS X v10.6, 于 2009 年 8 月 28 日 首次 提供 。Mac OS X 版 本 以 大 型 猫 科 
动物 的 名 字 命 名 ;Mac OS X 的 最 新 版 本 为 “雪豹 ”。 

(4) 其 他 

目前 仍 在 Niche 市 场 使 用 的 旧 操 作 系 统 包 括 来 自 IBM 和 微软 的 OS/2、Mac OS dE 
UNIX 基础 的 苹果 Mac OS X,BeOS, 、XTS-300。 有 些 操作 系统 (如 著名 的 Haiku, RISC 
OS , MorphOS 和 AmigaOS 4 ) 继续 发 展 为 发 烧 友 社区 和 专业 应 用 的 少数 人 平台 。 从 DEC 
形成 的 开放 VMS , 仍 由 惠普 积极 发 展 。 然 而 ,还 有 其 他 操作 系统 几乎 只 用 在 学 术 界 ,作为 
操作 系统 教育 或 在 其 上 做 操作 系统 的 概念 研究 。 同 时 履行 这 两 大 功能 的 典型 例子 是 
MINIX ,而 如 Singularity 纯粹 用 于 研究 。 


Text B BIOS 或 CMOS 设置 


BIOS 是 基本 输入 输出 系统 的 缩写 ,是 内 置 的 软件 ,决定 计算 机 可 以 做 什么 (如 不 从 
WEED] EAP), FE PC 上 ,BIOS 包含 所 有 控制 键盘 、 显示 屏 、 便 盘 驱 动 希 、 串 行 通信 ,以 
及 一 些 辅助 功能 所 需 的 代码 。 所 有 选项 如 图 11-1 ~ 图 11-3 所 示 。 

BIOS 通常 放置 在 计算 机 自 带 的 (这 通常 称 为 ROM BIOS) ROM 芯片 中 。 这 确保 了 
BIOS 将 始终 可 用 ,并 且 不 会 被 磁盘 故障 损坏 。 这 也 使 得 计算 机 自身 引导 有 可 能 。 因 为 
RAM It ROM 的 速度 快 ,虽然 很 多 计算 机 厂商 设计 系统 ,每 次 计算 机 启动 时 ,将 BIOS 从 
ROM 复制 到 RAM 中 ,这 称 为 投影 。 

由 于 存在 各 种 各 样 的 计算 机 和 BIOS 厂商 ,所 以 有 很 多 方法 可 以 进入 BIOS 或 CMOS 
设置 。 下 面 是 这 些 主要 方法 的 一 个 列表 ,以 及 用 于 输入 BIOS 设置 的 其 他 建议 。 

值得 庆 池 的 是 ,过 去 几 年 制造 的 计算 机 在 引导 过 程 中 已 经 可 以 让 你 按 以 下 5 个 键 之 
一 进入 CMOS, 

F1,F2,Del,Esc,Fl10 
通常 用 前 3 个 键 之 一 。 

用 户 在 计算 机 局 动 时 看 到 类 似 于 下 面 示 例 的 消息 时 ,会 知道 何 时 按 下 此 键 。 某 些 较 
日 的 计算 机 还 可 能 显示 一 个 闪烁 块 ,以 指示 何 时 按 Fl 或 F2 键 。 


Press < F2 > to enter BIOS setup (和 按 < 权 > 键 进 入 BIOS 设置 ) 


成 功 进 入 CMOS 设置 后 ,会 看 到 类 似 于 图 11-1 的 屏幕 。 
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